Nginx+Keepalived雙機熱備

一.Keepalived

Keepalived是保證集羣高可用的服務軟件網絡中優先級高的節點爲master負責響應VIP的ARP包,將VIP和MAC地址映射關係告訴網絡內其餘主機,還會以多播的形式向網絡中發送VRRP通告,告知本身的優先級。backup節點只負責處理master發出的多播包,當發現master的優先級沒本身高,或者沒收到master的VRRP通告時,backup將本身切換到master狀態。html

 

二.環境搭建

環境:QEMU-KVM、客戶機Debian(9.4.0)
虛擬機QEMU-KVM安裝:虛擬化技術QEMU-KVM入門linux

1.使用臨時快照建立兩臺虛擬機,如下操做兩臺虛擬機都須要執行
faramita2016@linux-l9e6:~> qemu-kvm -cpu host -m 512 -hda vdisk.img -net nic -net bridge,br=br0 -snapshot -nographic  nginx

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.激活網卡IPbash

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文件spa

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文件,除如下項,其它與主節點相同code

    state BACKUP    // 設置節點爲主節點,節點的初始狀態
    priority 10    // 節點優先級

3.在全部節點執行,建立監控腳本,編輯/root/chk_nginx.sh文件,用於監控nginx進程的運行,及關閉keepalived服務router

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已綁定備用節點

相關文章
相關標籤/搜索