Keepalived的作用是檢測(cè)web服務(wù)器的狀態(tài),如果有一臺(tái)web服務(wù)器、
Mysql服務(wù)器宕機(jī),或工作出現(xiàn)故障,Keepalived將檢測(cè)到后,會(huì)將有故
障的web服務(wù)器或者M(jìn)ysql服務(wù)器從系統(tǒng)中剔除,當(dāng)服務(wù)器工作正常后
Keepalived自動(dòng)將web、Mysql服務(wù)器加入到服務(wù)器群中。這些工作全部
自動(dòng)完成,不需要人工干涉,需要人工做的只是修復(fù)故障的WEB和Mysql
服務(wù)器。
生產(chǎn)環(huán)境使用Keepalived正常運(yùn)行,共啟動(dòng)3個(gè)進(jìn)程,一個(gè)是父進(jìn)程,負(fù)責(zé)
監(jiān)控其子進(jìn)程,一個(gè)是VRRP子進(jìn)程,另外一個(gè)是Checkers子進(jìn)程。兩個(gè)子
進(jìn)程都被系統(tǒng)Watchlog看管,兩個(gè)子進(jìn)程各自負(fù)責(zé)自己的事,
Healthcheck子進(jìn)程檢查各自服務(wù)器的健康狀況,如果Healthcheck進(jìn)程檢
查到Master上服務(wù)不可用了,就會(huì)通知本機(jī)上的VRRP子進(jìn)程,讓他刪除通
告,并且去掉虛擬IP,轉(zhuǎn)換為BACKUP狀態(tài)。
虛擬IP:192.168.80.200
nginx服務(wù)器:192.168.80.128-129
# nginx服務(wù)器上安裝keepalived工具:
yum install keepalived -y
# master端配置:
vim /etc/keepalived/keepalived.conf
router_id LVS_DEVEL:keepalived機(jī)器的標(biāo)識(shí),一般設(shè)為主機(jī)名
virtual_router_id 51:虛擬路由器id號(hào),主從必須一致
priority 100:優(yōu)先級(jí)(值越大,優(yōu)先級(jí)越大)
advert_int 1:檢測(cè)間隔時(shí)間(心跳頻率)

# backup端配置:

# 啟動(dòng)keepalived:
systemctl start keepalived
# 測(cè)試:
啟動(dòng)之后就可以看到vip的生成并且成功128服務(wù)器的nginx服務(wù)

關(guān)閉128服務(wù)器的nginx和keepalived:
nginx -s stop && systemctl stop keepalived
129成功獲得vip地址和成功訪問(wèn)到129服務(wù)器的nginx服務(wù)

測(cè)試成功?? 》》》》》》》
我們確實(shí)實(shí)現(xiàn)的vip能繼續(xù)提供服務(wù),但是nginx宕機(jī)時(shí),我們需要手動(dòng)關(guān)閉keepalived服務(wù),期間用戶訪問(wèn)會(huì)受到影響。下面我們就一起來(lái)是實(shí)現(xiàn)自動(dòng)切換。只需要在原先的配置文件添加幾行文檔,很簡(jiǎn)單的。
# 配置keepalived的master端
vim /etc/keepalived/keepalived.conf
scripts:指定一個(gè)腳本,判斷nginx是否宕機(jī)。
weight:宕機(jī)后優(yōu)先級(jí)減20(100=>80).
track_script:用來(lái)追蹤腳本

下面是檢測(cè)nginx是否宕機(jī)的腳本:

killall -0 nginx 判斷nginx是否處于啟動(dòng)狀態(tài)(啟動(dòng)返回0,沒(méi)啟動(dòng)返回1)
# 測(cè)試——成功
只模擬nginx宕機(jī)
