Nginx+Keepalived實(shí)現(xiàn)雙機(jī)熱備
一.Keepalived
Keepalived是保證集群高可用的服務(wù)軟件,網(wǎng)絡(luò)中優(yōu)先級(jí)高的節(jié)點(diǎn)為master負(fù)責(zé)響應(yīng)VIP的ARP包,將VIP和MAC地址映射關(guān)系告訴網(wǎng)絡(luò)內(nèi)其他主機(jī),還會(huì)以多播的形式向網(wǎng)絡(luò)中發(fā)送VRRP通告,告知自己的優(yōu)先級(jí)。backup節(jié)點(diǎn)只負(fù)責(zé)處理master發(fā)出的多播包,當(dāng)發(fā)現(xiàn)master的優(yōu)先級(jí)沒(méi)自己高,或者沒(méi)收到master的VRRP通告時(shí),backup將自己切換到master狀態(tài)。
二.環(huán)境搭建
- 環(huán)境:QEMU-KVM、客戶機(jī)Debian(9.4.0)
- 虛擬機(jī)QEMU-KVM安裝:虛擬化技術(shù)QEMU-KVM入門
1.使用臨時(shí)快照創(chuàng)建兩臺(tái)虛擬機(jī),以下操作兩臺(tái)虛擬機(jī)都需要執(zhí)行
faramita2016@linux-l9e6:~> qemu-kvm -cpu host -m 512 -hda vdisk.img -net nic -net bridge,br=br0 -snapshot -nographic
2.設(shè)置虛擬機(jī)靜態(tài)IP
root@debian:~# cat /etc/network/interfaces # The primary network interface allow-hotplug ens3 #iface ens3 inet dhcp iface ens3 inet static address 10.0.0.3 // 設(shè)置ip netmask 255.0.0.0 gateway 10.0.0.1 hwaddress ether 52:54:00:12:34:53 // 設(shè)置mac地址
3.激活網(wǎng)卡IP
root@debian:~# ip addr del 10.0.0.8/8 dev ens3 // 刪除客戶機(jī)原有IP root@debian:~# ifdown ens3 root@debian:~# ifup ens3
4.安裝Nginx、Keepalived
root@debian:~# apt-get install -y nginx keepalived
5.修改/var/www/html/index.nginx-debian.html文件,添加當(dāng)前虛擬機(jī)ip,用于標(biāo)記實(shí)際響應(yīng)的服務(wù)器
root@debian:~# vi /var/www/html/index.nginx-debian.html …… <h1>Welcome to nginx! 10.0.0.3</h1> ……
三.軟件配置
主節(jié)點(diǎn)虛擬機(jī)(10.0.0.3),備用節(jié)點(diǎn)虛擬機(jī)(10.0.0.4),虛擬IP(10.0.0.100)
1.在主節(jié)點(diǎn)虛擬機(jī),編輯/etc/keepalived/keepalived.conf文件
root@debian:~# cat /etc/keepalived/keepalived.conf global_defs { router_id RI_1 // 標(biāo)識(shí)當(dāng)前keepalived節(jié)點(diǎn) } vrrp_script chk_nginx { script "/root/chk_nginx.sh" // 定義監(jiān)控腳本 interval 2 // 執(zhí)行監(jiān)控腳本的鬧中間隔時(shí)間 } vrrp_instance VI_1 { state MASTER // 設(shè)置節(jié)點(diǎn)為主節(jié)點(diǎn),節(jié)點(diǎn)的初始狀態(tài) interface ens3 // 設(shè)置綁定虛擬ip的網(wǎng)絡(luò)接口 virtual_router_id 50 // VRRP組名,指明節(jié)點(diǎn)同屬一個(gè)組 priority 100 // 節(jié)點(diǎn)優(yōu)先級(jí),主節(jié)點(diǎn)應(yīng)當(dāng)高于備用節(jié)點(diǎn) advert_int 1 // 組播信息發(fā)送間隔 #nopreempt // 禁止搶占服務(wù),只對(duì)備用節(jié)點(diǎn)生效,主節(jié)點(diǎn)根據(jù)priority優(yōu)先級(jí)進(jìn)行搶占,不受nopreempty控制 authentication { auth_type PASS // 設(shè)置認(rèn)證方式 auth_pass 123456 // 密碼 } virtual_ipaddress { 10.0.0.100/24 // 設(shè)置vip } track_script { // 調(diào)用監(jiān)控腳本 chk_nginx } }
2.在備用節(jié)點(diǎn)虛擬機(jī),編輯/etc/keepalived/keepalived.conf文件,除以下項(xiàng),其它與主節(jié)點(diǎn)相同
state BACKUP // 設(shè)置節(jié)點(diǎn)為主節(jié)點(diǎn),節(jié)點(diǎn)的初始狀態(tài) priority 10 // 節(jié)點(diǎn)優(yōu)先級(jí)
3.在所有節(jié)點(diǎn)執(zhí)行,創(chuàng)建監(jiān)控腳本,編輯/root/chk_nginx.sh文件
root@debian:~# vi /root/chk_nginx.sh #!/bin/bash A=`ps -C nginx --no-header | wc -l` if [ $A -eq 0 ] then /etc/init.d/keepalived stop fi
四.驗(yàn)證服務(wù)
1.主節(jié)點(diǎn)虛擬機(jī),啟動(dòng)nginx和keepalived服務(wù)
root@debian:~# /etc/init.d/nginx start root@debian:~# /etc/init.d/keepalived start
執(zhí)行ip a命令,主節(jié)點(diǎn)網(wǎng)卡ens3已綁定vip(10.0.0.100)
2.在備用節(jié)點(diǎn)虛擬機(jī),啟動(dòng)nginx和keepalived服務(wù)
root@debian:~# /etc/init.d/nginx start root@debian:~# /etc/init.d/keepalived start
執(zhí)行ip a命令,備用節(jié)點(diǎn)網(wǎng)卡ens3未綁定vip(10.0.0.100)
3.宿主機(jī)瀏覽器訪問(wèn)http://10.0.0.100
出現(xiàn)10.0.0.3的網(wǎng)頁(yè),說(shuō)明keepalived服務(wù)已生效,vip已綁定主節(jié)點(diǎn)
4.在主節(jié)點(diǎn)虛擬機(jī),關(guān)閉nginx服務(wù),模擬宕機(jī)
root@debian:~# /etc/init.d/nginx stop
執(zhí)行ip a命令,主節(jié)點(diǎn)網(wǎng)卡ens3未綁定vip(10.0.0.100)
5.在備用節(jié)點(diǎn)虛擬機(jī),查詢ip
執(zhí)行ip a命令,備用節(jié)點(diǎn)網(wǎng)卡ens3已綁定vip(10.0.0.100)
6.宿主機(jī)瀏覽器訪問(wèn)http://10.0.0.100
出現(xiàn)10.0.0.4的網(wǎng)頁(yè),說(shuō)明keepalived服務(wù)已生效,vip已綁定備用節(jié)點(diǎn)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- nginx keepalive的具體使用
- nginx+keepalived 高可用主從配置詳解
- nginx中keepalive配置詳解
- Nginx結(jié)合keepalived實(shí)現(xiàn)雙機(jī)熱備方案
- 生產(chǎn)環(huán)境部署Nginx服務(wù)器雙機(jī)熱備部署keepalived的步驟(多種模式教程)
- Nginx+Keepalived實(shí)現(xiàn)雙機(jī)主備的方法
- keepalived+nginx高可用實(shí)現(xiàn)方法示例
- nginx配置keepalive長(zhǎng)連接的實(shí)現(xiàn)方法
- nginx結(jié)合keepalived實(shí)現(xiàn)高可用的完整步驟
- Nginx連接保持超時(shí)(keepalive_timeout)配置小結(jié)
相關(guān)文章
Nginx域名轉(zhuǎn)發(fā)使用場(chǎng)景代碼實(shí)例
這篇文章主要介紹了Nginx域名轉(zhuǎn)發(fā)使用場(chǎng)景代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09負(fù)載均衡下的webshell上傳+nginx解析漏洞的過(guò)程
這篇文章主要介紹了負(fù)載均衡下的webshell上傳+nginx解析漏洞,首先介紹了負(fù)載均衡下webshell上傳的四大難點(diǎn)及環(huán)境搭建教程,感興趣的朋友跟隨小編一起看看吧2024-02-02利用Nginx反向代理功能解決WEB網(wǎng)站80端口被封的解決方法
大陸的網(wǎng)絡(luò)環(huán)境,都在天朝神獸的制度下讓我等小P民悲劇一片;動(dòng)不動(dòng)就拔網(wǎng)線、封機(jī)房;現(xiàn)在更厲害的一招,從網(wǎng)關(guān)封殺你的80端口,一旦被封,網(wǎng)站域名就無(wú)法訪問(wèn)2012-08-08解決nginx已經(jīng)配置過(guò)跨域不生效問(wèn)題
這篇文章主要介紹了解決nginx已經(jīng)配置過(guò)跨域不生效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12通過(guò)lua來(lái)配置實(shí)現(xiàn)Nginx服務(wù)器的防盜鏈功能
這篇文章主要介紹了通過(guò)lua來(lái)配置實(shí)現(xiàn)Nginx服務(wù)器的防盜鏈功能的方法,這里主要講解生成鏈接的Nginx配置,需要的朋友可以參考下2016-01-01Nginx+SSL實(shí)現(xiàn)雙向認(rèn)證的示例代碼
這篇文章主要介紹了Nginx+SSL實(shí)現(xiàn)雙向認(rèn)證的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01nginx 配置代理服務(wù)地址最后多加反斜杠和不加反斜杠的區(qū)別小結(jié)
在使用Nginx配置代理服務(wù)時(shí),地址最后是否添加反斜杠(/)會(huì)對(duì)代理的URL處理產(chǎn)生影響,下面就來(lái)具體介紹一下,感興趣的可以了解一下2024-08-08nginx常見(jiàn)內(nèi)置變量$uri和$request_uri的使用
本文主要介紹了nginx常見(jiàn)內(nèi)置變量$uri和$request_uri的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07