一.keepalived
keepalived是保證集群高可用的服務軟件,網絡中優先級高的節點為master負責響應vip的arp包,將vip和mac地址映射關系告訴網絡內其他主機,還會以多播的形式向網絡中發送vrrp通告,告知自己的優先級。backup節點只負責處理master發出的多播包,當發現master的優先級沒自己高,或者沒收到master的vrrp通告時,backup將自己切換到master狀態。
二.環境搭建
1.使用臨時快照創建兩臺虛擬機,以下操作兩臺虛擬機都需要執行
faramita2016@linux-l9e6:~>?qemu-kvm?-cpu?host?-m?512?-hda?vdisk.img?-net?nic?-net?bridge,br=br0?-snapshot?-nographic
2.設置虛擬機靜態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??//?設置ip netmask?255.0.0.0 gateway?10.0.0.1 hwaddress?ether?52:54:00:12:34:53??//?設置mac地址
3.激活網卡ip
root@debian:~#?ip?addr?del?10.0.0.8/8?dev?ens3??//?刪除客戶機原有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文件,添加當前虛擬機ip,用于標記實際響應的服務器
root@debian:~#?vi?/var/www/html/index.nginx-debian.html? …… <h1>welcome?to?nginx!?10.0.0.3</h1> ……
三.軟件配置
主節點虛擬機(10.0.0.3),備用節點虛擬機(10.0.0.4),虛擬ip(10.0.0.100)
1.在主節點虛擬機,編輯/etc/keepalived/keepalived.conf文件
root@debian:~#?cat?/etc/keepalived/keepalived.conf? global_defs?{ ??router_id?ri_1??//?標識當前keepalived節點 } vrrp_script?chk_nginx?{ ??script?"/root/chk_nginx.sh"??//?定義監控腳本 ??interval?2??//?執行監控腳本的鬧中間隔時間 } vrrp_instance?vi_1?{ ??state?master??//?設置節點為主節點,節點的初始狀態 ??interface?ens3??//?設置綁定虛擬ip的網絡接口 ??virtual_router_id?50??//?vrrp組名,指明節點同屬一個組 ??priority?100??//?節點優先級,主節點應當高于備用節點 ??advert_int?1??//?組播信息發送間隔 ??#nopreempt??//?禁止搶占服務,只對備用節點生效,主節點根據priority優先級進行搶占,不受nopreempty控制 ??authentication?{ ????auth_type?pass??//?設置認證方式 ????auth_pass?123456??//?密碼 ??} ??virtual_ipaddress?{ ????10.0.0.100/24??//?設置vip ??} ??track_script?{??//?調用監控腳本 ????chk_nginx ??} }
2.在備用節點虛擬機,編輯/etc/keepalived/keepalived.conf文件,除以下項,其它與主節點相同
state?backup??//?設置節點為主節點,節點的初始狀態 ??priority?10??//?節點優先級
3.在所有節點執行,創建監控腳本,編輯/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
四.驗證服務
1.主節點虛擬機,啟動nginx和keepalived服務
root@debian:~#?/etc/init.d/nginx?start root@debian:~#?/etc/init.d/keepalived?start
執行ip a命令,主節點網卡ens3已綁定vip(10.0.0.100)
2.在備用節點虛擬機,啟動nginx和keepalived服務
root@debian:~#?/etc/init.d/nginx?start root@debian:~#?/etc/init.d/keepalived?start
執行ip a命令,備用節點網卡ens3未綁定vip(10.0.0.100)
3.宿主機瀏覽器訪問http://10.0.0.100
出現10.0.0.3的網頁,說明keepalived服務已生效,vip已綁定主節點
4.在主節點虛擬機,關閉nginx服務,模擬宕機
root@debian:~#?/etc/init.d/nginx?stop
執行ip a命令,主節點網卡ens3未綁定vip(10.0.0.100)
5.在備用節點虛擬機,查詢ip
執行ip a命令,備用節點網卡ens3已綁定vip(10.0.0.100)
6.宿主機瀏覽器訪問http://10.0.0.100
出現10.0.0.4的網頁,說明keepalived服務已生效,vip已綁定備用節點