1. 程式人生 > >集群介紹,keepalived介紹,keepalived配置高可用集群

集群介紹,keepalived介紹,keepalived配置高可用集群

keepalived 高可用集群

Linux集群概述

根據功能劃分為兩大類:高可用和負載均衡
高可用集群通常為兩臺服務器,一臺工作,另外一臺作為冗余,當提供服務的機器宕機,冗余將接替繼續提供服務
實現高可用的開源軟件有:heartbeat、keepalived (推薦)
負載均衡集群,需要有一臺服務器作為分發器,它負責把用戶的請求分發給後端的服務器處理,在這個集群裏,除了分發器外,就是給用戶提供服務的服務器了,這些服務器數量至少為2
實現負載均衡的開源軟件有LVS、keepalived、haproxy、nginx,商業的有F5、Netscaler

keepalived介紹

keepalived通過VRRP(Virtual Router Redundancy Protocl)來實現高可用。

在這個協議裏會將多臺功能相同的路由器組成一個小組,這個小組裏會有1個master角色(主角色)和N(N>=1)個backup角色(備用角色)。
master會通過組播的形式向各個backup發送VRRP協議的數據包,當backup收不到master發來的VRRP數據包時,就會認為master宕機了。此時就需要根據各個backup的優先級來決定誰成為新的mater。
Keepalived要有三個模塊,分別是core、check和vrrp。其中core模塊為keepalived的核心,負責主進程的啟動、維護以及全局配置文件的加載和解析,check模塊負責健康檢查,vrrp模塊是來實現VRRP協議的。

用keepalived配置高可用集群

準備兩臺機器自定義107和109,107作為master,109作為backup。
兩臺機器都執行yum install -y keepalived
在生產環境中,諸多企業將Nginx作為負載均衡器來使用,一旦宕機,整個網站都會癱瘓,所以有必要在準備一臺備用Nginx,keepalived在這種場景下就非常合適了。所以keepalived+Nginx可以實現web的高可用。所以兩臺設備都要安裝nginx。
第一臺107已經安裝,我們要在第二臺109上裝nginx
yum install -y nginx
這時可能會報錯,已加載插件:fastestmirror
Loading mirror speeds from cached hostfile

  • base: mirrors.tuna.tsinghua.edu.cn
  • extras: mirrors.tuna.tsinghua.edu.cn
  • updates: mirrors.aliyun.com
    沒有可用軟件包 nginx。
    錯誤:無須任何處理
    這時我們需要添加nginx的源
    rpm -ivh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
    然後再yum安裝。

然後我們配置107主上的keepalived配置文件
vim /etc/keepalived/keepalived.conf,我們需要將裏面的內容清空。
我們可以去
https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D21Z/master_keepalived.conf獲取模板。
global_defs {
notification_email {[email protected]
br/>[email protected]
notification_email_from [email protected]
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}
vrrp_script chk_nginx {
script "/usr/local/sbin/check_ng.sh"
interval 3
}
vrrp_instance VI_1 {
state MASTER
interface ens33
virtual_router_id 51
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass aminglinux>com
}
virtual_ipaddress {
192.168.188.100
}
track_script {
chk_nginx
}
}

這裏我們要將 virtual_ipaddress 192.168.1.100設定為100。100為公共ip

然後我們去定義一個監控腳本,他可以在https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D21Z/master_check_ng.sh獲取
我們的監控腳本路徑就是在我們定義keepalived.conf時,vrrp_script chk_nginx {
script "/usr/local/sbin/check_ng.sh"
interval 3
時定義的路徑。

腳本內容
#!/bin/bash
#時間變量,用於記錄日誌
d=date --date today +%Y%m%d_%H:%M:%S
#計算nginx進程數量
n=ps -C nginx --no-heading|wc -l
#如果進程為0,則啟動nginx,並且再次檢測nginx進程數量,
#如果還為0,說明nginx無法啟動,此時需要關閉keepalived
if [ $n -eq "0" ]; then
/etc/init.d/nginx start
n2=ps -C nginx --no-heading|wc -l
if [ $n2 -eq "0" ]; then
echo "$d nginx down,keepalived will stop" >> /var/log/check_ng.log
systemctl stop keepalived
fi
fi

然後我們給腳本做個權限變更
chmod 755 /usr/local/sbin/check_ng.sh

132上編輯配置文件
內容從https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D21Z/backup_keepalived.conf獲取
global_defs {
notification_email {[email protected]
br/>[email protected]
notification_email_from [email protected]
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}
vrrp_script chk_nginx {
script "/usr/local/sbin/check_ng.sh"
interval 3
}
vrrp_instance VI_1 {
state BACKUP
interface ens33
virtual_router_id 51
priority 90
advert_int 1
authentication {
auth_type PASS
auth_pass aminglinux>com
}
virtual_ipaddress {
192.168.188.100
}
track_script {
chk_nginx
}
}

132上編輯監控腳本
內容從https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D21Z/backup_checkng.sh獲取
#時間變量,用於記錄日誌
d=`date --date today +%Y%m%d
%H:%M:%S<br/>#計算nginx進程數量<br/>n=ps -C nginx --no-heading|wc -l<br/>#如果進程為0,則啟動nginx,並且再次檢測nginx進程數量,<br/>#如果還為0,說明nginx無法啟動,此時需要關閉keepalived<br/>if [ $n -eq "0" ]; then<br/>systemctl start nginx<br/>n2=ps -C nginx --no-heading|wc -l`
if [ $n2 -eq "0" ]; then
echo "$d nginx down,keepalived will stop" >> /var/log/check_ng.log
systemctl stop keepalived
fi
fi

給腳本755權限
132上也啟動服務 systemctl start keepalived

集群介紹,keepalived介紹,keepalived配置高可用集群