六十一、集群介紹、keepalived介紹、用keepaliver配置高可用集群
一、集群介紹
根據功能劃分為兩大類:高可用和負載均衡。
高可用集群通常為兩臺服務器,一臺工作,另外一臺作為冗余,當提供服務的機器宕機,冗余將接替繼續提供服務
實現高可用的開源軟件有:heartbeat、keepalived。heartbeat有很多bug,所以不再使用。
負載均衡集群,需要有一臺服務器作為分發器,它負責把用戶的請求分發給後端的服務器處理,在這個集群裏,除了分發器外,就是給用戶提供服務的服務器了,這些服務器數量至少為2
實現負載均衡的開源軟件有LVS、keepalived、haproxy、nginx,商業的負載均衡器有F5、Netscaler,相當於一臺設備,優勢是有更高的並發量,有很好的穩定性;開源的軟件做負載均衡穩定性就取決於服務器的穩定性了。
二、keepalived介紹
我們使用keepalived來實現高可用集群,因為heartbeat在centos6上有一些問題,影響實驗效果,缺點:切換不及時,通信不順暢。
keepalived通過VRRP協議(Virtual Router Redundancy Protocl)來實現高可用,是它的核心。虛擬路由冗余協議。
在這個協議裏會將多臺功能相同的路由器組成一個小組,這個小組裏會有1個master角色(主角色)和N(N>=1)個backup角色,通常這個N=1就可以實現了。
master會通過組播的形式向各個backup發送VRRP協議的數據包,當backup收不到master發來的VRRP數據包時,就會認為master宕機了。此時就需要根據各個backup的優先級來決定誰成為新的mater。
Keepalived要有三個模塊,分別是core、check和vrrp。
core模塊為keepalived的核心,負責主進程的啟動、維護以及全局配置文件的加載和解析;
check模塊負責健康檢查;
vrrp模塊是來實現VRRP協議的。
三、用keepaliver配置高可用集群
準備兩臺機器130和129,130作為master,129作為backup
兩臺機器都執行yum install -y keepalived
兩臺機器都安裝nginx,其中130上已經編譯安裝過nginx,129上需要yum安裝nginx: # yum install -y pcp-pmda-nginx
設定vip為100
編輯130上keepalived配置文件
先清空原來文件裏的內容,# > /etc/keepalived/keepalived.conf
再把下面的內容粘貼進去:
# vim /etc/keepalived/keepalived.conf
global_defs { //global,全局定義
notification_email { //出現問題時,給一個郵箱發郵件
aming@aminglinux.com
}
notification_email_from root@aminglinux.com //由哪個郵件發出去,就是發件人
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 //檢測的間斷是3秒鐘。
}
vrrp_instance VI_1 {
state MASTER //這一段是定義master的一些內容的,這行定義角色。
interface ens33 //通信,發廣播的網卡。
virtual_router_id 51 //定義你路由器的id是什麽,和從的id要保持一致,說明他們是一組
priority 100 //權重,主比從要高。
advert_int 1
authentication { //這三行是認證相關的信息。
auth_type PASS //定義認證的類型是pass,密碼。
auth_pass aminglinux>com //定義密碼,一個字符串。
}
virtual_ipaddress {
192.168.93.100 //主和從的公有IP,這個就叫VIP,主需要綁定這個ip,當主宕機了,從就需要起來綁定這個ip。
}
track_script {
chk_nginx //對檢查腳本做一個加載。
}
}
130編輯監控腳本,內容
# vim /usr/local/sbin/check_ng.sh //這個腳本名字是自定義的,配置文件寫的什麽,這裏就寫那個名字。
#!/bin/bash
d=`date --date today +%Y%m%d_%H:%M:%S` //時間變量,用於記錄日誌
n=`ps -C nginx --no-heading|wc -l` //計算nginx進程數量
if [ $n -eq "0" ]; then
//如果進程為0,說明nginx沒啟動,則啟動nginx,並且再次檢測nginx進程數量,
//如果還為0,說明nginx無法啟動,此時需要關閉keepalived
/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 //停掉keepalived
fi
fi
給腳本755權限chmod 755 /usr/local/sbin/check_ng.sh
systemctl start keepalived 130啟動服務
即使停止也會自動起來,查看這個VIP要用ip
add才能看到它,ifconfig是看不到的。
主和從的防火墻和selinux都要關閉,防火墻如果有就關閉firewalld。
129上編輯配置文件,內容:
# > /etc/keepalived/keepalived.conf
# vim /etc/keepalived/keepalived.conf
global_defs {
notification_email {
aming@aminglinux.com
}
notification_email_from root@aminglinux.com
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 //這裏是BACKUP
interface ens33
virtual_router_id 51 //這裏和主保持一致。
priority 90 //權重,比主少10。
advert_int 1
authentication {
auth_type PASS
auth_pass aminglinux>com
}
virtual_ipaddress {
192.168.93.100
}
track_script {
chk_nginx
}
}
129上編輯監控腳本,內容
# vim /usr/local/sbin/check_ng.sh
d=`date --date today +%Y%m%d_%H:%M:%S` #時間變量,用於記錄日誌
n=`ps -C nginx --no-heading|wc -l` #計算nginx進程數量
if [ $n -eq "0" ]; then
#如果進程為0,則啟動nginx,並且再次檢測nginx進程數量,
#如果還為0,說明nginx無法啟動,此時需要關閉keepalived
systemctl start nginx
//和主的啟動命令不一樣,因為主是編譯安裝的,啟動腳本是自定義的,而從是yum安裝的。
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權限# chmod 755 /usr/local/sbin/check_ng.sh,不改權限就不能啟動。
129上也啟動服務 systemctl start keepalived
backup的默認頁:/usr/share/nginx/html/index.html
用瀏覽器訪問以下192.168.93.130和129,再訪問他們的公有IP,就可以看到現在是綁定了master。
測試高可用
先確定好兩臺機器上nginx差異,比如可以通過curl -I 來查看nginx版本
測試1:關閉master上的nginx服務
測試2:在master上增加iptabls規則
iptables -I OUTPUT -p vrrp -j DROP
測試3:關閉master上的keepalived服務
測試4:啟動master上的keepalived服務
多個backup角色就將權重設置不一樣,誰的權重更高,就由誰來接替master的角色。
擴展
heartbeat和keepalived比較http://blog.csdn.net/yunhua_lee/article/details/9788433
DRBD工作原理和配置 http://502245466.blog.51cto.com/7559397/1298945
mysql+keepalived http://lizhenliang.blog.51cto.com/7876557/1362313
六十一、集群介紹、keepalived介紹、用keepaliver配置高可用集群