1. 程式人生 > >六十一、集群介紹、keepalived介紹、用keepaliver配置高可用集群

六十一、集群介紹、keepalived介紹、用keepaliver配置高可用集群

集群介紹 Keepalived介紹 用Keepalived配置高可用集群

六十一、集群介紹、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配置高可用集群