]# rm .ssh/known_hosts
清除以前ssh連接;
* 使用兩臺主機:
**安裝keepalived程序包、http服務;**
**啓動web服務;**
* 要高可用http服務,默認情況下keepalived是沒有這功能的,需要藉助外在腳本完成高可用功能;
* 編輯keepalived配置文件
```
]# vim /etc/keepalived/keepalived.conf
```
###配置服務高可用,只需保留vrrp_instance實例段和全局配置段即可;###
* 在演示高可用http服務之前,先演示rrp_script、track_script是如何使用的;
* **如果想臨時測試keepalived的流轉,實現主備切換,之前只能通過停止keepalived服務才能實現;通過此兩個腳本可實現不同停止keepalived服務,就可實現主備切
換;**
* **在keepalived配置文件目錄下,可判定一個down文件是否存在,如果此文件存在,就認爲服務要維護,於是降低該服務器的優先級,而不是把keepalived服務停掉;如果該文件不存在,會把優先級再升回去;**
* **因此,可寫一個腳本監控在一個指定位置是否存在某一文件,如果文件在了,就降低優先級;**
* 於是編輯兩臺主機的keepalived配置文件 【此處是:註釋說明】:
```
主節點:172.18.11.111
備節點:172.18.11.121
VIP:172.18.11.7
]# vim /etc/keepalived/keepalived.conf
------------------------------------------------------------------------------------------
global_defs {
notification_email {
root@localhost
}
notification_email_from [email protected]
smtp_server 172.0.0.1
smtp_connect_timeout 30
router_id node1
vrrp_mcast_group4 224.0.11.18
}
vrrp_script chk_down { 【自定義vrrp腳本調用名爲chk_down】
script "[[ -f /etc/keepalived/down ]] && exit 1 || exit 0" 【文件存在,退出碼1,不存在則返回0;】
interval 2 【每個2秒檢查一次;】
weight -5 【檢測失敗則權重-5;成功將不執行;可使用rpm -ql keepalived查詢是否有樣例文件可參看;】
}
vrrp_instance VI_1 {
state MASTER
interface eno16777736
virtual_router_id 11
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass vHFHLlTA
}
virtual_ipaddress {
172.18.11.7 dev eno16777736 label eno16777736:0
}
track_script { 【調用上面自定義的vrrp腳本調用名】
chk_down
}
notify_master "/etc/keepalived/notify.sh master"
notify_backup "/etc/keepalived/notify.sh backup"
notify_fault "/etc/keepalived/notify.sh fault"
}
【複製到另一主機:】
]# scp keepalived.conf [email protected]:/etc/keepalived/
【修改部分內容:】
state BACKUP
priority 98
【啓動備節點上的keepalived服務:】
]# systemctl start keepalived.service
【參看日誌文件:】
]# tail /var/log/messages
]# ifconfig 【已經獲取VIP地址爲172.18.11.7】
【再啓動主節點的keepalived服務:】
]# systemctl start keepalived.service
【主節點優先級高,所以已經把VIP搶佔了;實現了地址浮動;】
]# ifconfig
【創建down文件】
]# touch /etc/keepalived/down
此時,地址應該已經沒有了;
【在備用節點查看,地址已經浮動過來了:】
]# ifconfig
【在主節點刪除down文件,還會把VIP地址搶佔回來】
]# rm /etc/keepalived/down
]# ifconfig
【這就是vrrp_script、rack_script腳本基本工作機制;】
【可利用這樣的腳本來判斷http服務是否ok,實現出現故障時,地址自動浮動到另一節點上繼續提供服務;】
【要判斷一個服務是否在線,腳本應寫的越簡單越好;】
]# killall -0 httpd 【0信號用於判斷一個進程是否運行正常,如果運行正常就返回成功,運行不正常就返回失敗,但不會真正kill 那個進程。】
]# echo $?
顯示爲0 【則表示http進程正常運行,返回成功】
【沒有killall命令,需要安裝psmisc程序包】
]# yum -y install psmisc
【停止http服務後測試:】
]# killall -0 httpd
httpd: no process found
]# echo $?
【顯示爲1】
```
【在兩個主備節點上,編輯keepalived配置文件:使用killall命令判斷服務是否OK】 【此處:實驗源碼】
```
]# vim /etc/keepalived/keepalived.conf
---------------------------------------------------------------------------------------------------
global_defs {
notification_email {
root@localhost
}
notification_email_from [email protected]
smtp_server 172.0.0.1
smtp_connect_timeout 30
router_id node1
vrrp_mcast_group4 224.0.11.18
}
vrrp_script chk_down {
script "[[ -f /etc/keepalived/down ]] && exit 1 || exit 0"
interval 2
weight -5
}
vrrp_script chk_httpd {
script "killall -0 httpd"
interval 2
weight 5
}
vrrp_instance VI_1 {
state MASTER
interface eno16777736
virtual_router_id 11
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass vHFHLlTA
}
virtual_ipaddress {
172.18.11.7 dev eno16777736 label eno16777736:0
}
track_script {
chk_down
chk_httpd
}
notify_master "/etc/keepalived/notify.sh master"
notify_backup "/etc/keepalived/notify.sh backup"
notify_fault "/etc/keepalived/notify.sh fault"
}
]# scp keepalived.conf [email protected]:/etc/keepalived/
【編輯配置文件】
]# vim /etc/keepalived/keepalived.conf
-------------------------------------------------------------------------------
【修改部分內容:】
state BACKUP
priority 98
【把主備節點的keepalived服務都停止;】
]# systemctl stop keepalived.service
【先啓動備用節點keepalived服務、查看是否獲得VIP:】
]# systemctl start keepalived.service
]# ifconfig
]# tail /var/log/messages
【已經獲得vip】
【再啓動主節點keepalived服務、查看是否搶佔VIP:】
]# systemctl start keepalived.service
]# ifconfig
【已經搶佔VIP;】
【在主節點上停用http服務】
]# systemctl stop httpd.service
]# ifconfig
【查看其VIP地址,已經消失;】
【在備用節點查看,獲得了VIP】
]# ifconfig
```
以上演示的就是使用vrrp_script腳本來監控具體服務,從而使用keepalived實現高可用一個服務;