日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

使用keepalived实现双机热备

發(fā)布時間:2023/12/9 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用keepalived实现双机热备 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

2019獨角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>

通常說的雙機熱備是指兩臺機器都在運行,但并不是兩臺機器都同時在提供服務(wù)。
當(dāng)提供服務(wù)的一臺出現(xiàn)故障的時候,另外一臺會馬上自動接管并且提供服務(wù),而且切換的時間非常短。
下面來以keepalived結(jié)合tomcat來實現(xiàn)一個web服務(wù)器的雙機熱備。
keepalived的工作原理是VRRP(Virtual Router Redundancy Protocol)虛擬路由冗余協(xié)議。
在VRRP中有兩組重要的概念:VRRP路由器和虛擬路由器,主控路由器和備份路由器。
VRRP路由器是指運行VRRP的路由器,是物理實體,虛擬路由器是指VRRP協(xié)議創(chuàng)建的,是邏輯概念。一組VRRP路由器協(xié)同工作,共同構(gòu)成一臺虛擬路由器。 Vrrp中存在著一種選舉機制,用以選出提供服務(wù)的路由即主控路由,其他的則成了備份路由。當(dāng)主控路由失效后,備份路由中會重新選舉出一個主控路由,來繼續(xù)工作,來保障不間斷服務(wù)。
我們在本文中的測試環(huán)境如下
兩臺物理服務(wù)器和一個虛擬服務(wù)器(vip):
master:redhat 2.6.18-53.el5? 192.168.8.4
backup: redhat 2.6.18-53.el5? 192.168.8.6
vip: 192.168.8.100
測試環(huán)境的網(wǎng)絡(luò)topology圖如下:

節(jié)點A 192.168.8.4 (主節(jié)點), 節(jié)點B 192.168.8.6(備用節(jié)點),虛擬IP(對外提供服務(wù)的IP 192.168.8.100)
在這種模式下,虛擬IP在某時刻只能屬于某一個節(jié)點,另一個節(jié)點作為備用節(jié)點存在。
當(dāng)主節(jié)點不可用時,備用節(jié)點接管虛擬IP(即虛擬IP漂移至節(jié)點B),提供正常服務(wù)。
keepalived的原理可以這樣簡單理解:
keepalived安裝在兩臺物理服務(wù)器上,并相互監(jiān)控對方是否在正常運行。
當(dāng)節(jié)點A正常的時候:節(jié)點A上的keepalived會將下面的信息廣播出去:
192.168.8.100 這個IP對應(yīng)的MAC地址為節(jié)點A網(wǎng)卡的MAC地址
圖中的其它電腦如客戶端和NodeB會更新自己的ARP表,對應(yīng)192.168.8.100的MAC地址=節(jié)點A網(wǎng)卡的MAC地址。
當(dāng)節(jié)點A發(fā)生故障的時候,節(jié)點B上的keepalived會檢測到,并且將下面的信息廣播出去:
192.168.8.100 這個IP對應(yīng)的MAC地址為節(jié)點B網(wǎng)卡的MAC地址
圖中的其它電腦如客戶端會更新自己的ARP表,對應(yīng)192.168.8.100的MAC地址=節(jié)點B網(wǎng)卡的MAC地址。

1,在主備機器上安裝keepalived,
步驟如下:下載keepalived-1.1.15.tar.gz,然后解壓安裝
#tar zxvf keepalived-1.1.15.tar.gz
#cd keepalived-1.1.15
#./configure
#make
#make install
2,配置keepalived
配置中的state MASTER決定了節(jié)點為主節(jié)點
priority決定了優(yōu)先級,比如在有多個備用節(jié)點的時候,主節(jié)點故障后優(yōu)先級值大的接管。
主節(jié)點的配置如下:

global_defs?{router_id?NodeA } vrrp_instance?VI_1?{state?MASTER????#設(shè)置為主服務(wù)器interface?eth0??#監(jiān)測網(wǎng)絡(luò)接口virtual_router_id?51??#主、備必須一樣priority?100???#(主、備機取不同的優(yōu)先級,主機值較大,備份機值較小,值越大優(yōu)先級越高)advert_int?1???#VRRP?Multicast廣播周期秒數(shù)authentication?{auth_type?PASS??#VRRP認(rèn)證方式,主備必須一致auth_pass?1111???#(密碼) } virtual_ipaddress?{192.168.8.100/24??#VRRP?HA虛擬地址 }

備用節(jié)點的配置如下:

global_defs?{router_id?NodeB } vrrp_instance?VI_1?{state?BACKUP????#設(shè)置為主服務(wù)器interface?eth0??#監(jiān)測網(wǎng)絡(luò)接口virtual_router_id?51??#主、備必須一樣priority?90???#(主、備機取不同的優(yōu)先級,主機值較大,備份機值較小,值越大優(yōu)先級越高)advert_int?1???#VRRP?Multicast廣播周期秒數(shù)authentication?{auth_type?PASS??#VRRP認(rèn)證方式,主備必須一致auth_pass?1111???#(密碼) } virtual_ipaddress?{192.168.8.100/24??#VRRP?HA虛擬地址 }

3,啟動keepalived:
keepalived -D -f /usr/local/etc/keepalived/keepalived.conf
查看log消息:
tail -f /var/log/messages
啟動主節(jié)點A后的日志為:會廣播ARP消息

[root@srv4?~]#?tail?-f?/var/log/messages Sep?20?01:45:29?srv4?Keepalived_vrrp:?Configuration?is?using?:?34546?Bytes Sep?20?01:45:29?srv4?Keepalived_vrrp:?VRRP?sockpool:?[ifindex(2),?proto(112),?fd(8,9)] Sep?20?01:45:30?srv4?Keepalived_vrrp:?VRRP_Instance(VI_1)?Transition?to?MASTER?STATE Sep?20?01:45:31?srv4?Keepalived_vrrp:?VRRP_Instance(VI_1)?Entering?MASTER?STATE Sep?20?01:45:31?srv4?Keepalived_vrrp:?VRRP_Instance(VI_1)?setting?protocol?VIPs. Sep?20?01:45:31?srv4?Keepalived_vrrp:?VRRP_Instance(VI_1)?Sending?gratuitous?ARPs?on?eth0?for?192.168.8.100 Sep?20?01:45:31?srv4?Keepalived_vrrp:?Netlink?reflector?reports?IP?192.168.8.100?added Sep?20?01:45:31?srv4?Keepalived_healthcheckers:?Netlink?reflector?reports?IP?192.168.8.100?added Sep?20?01:45:31?srv4?avahi-daemon[4029]:?Registering?new?address?record?for?192.168.8.100?on?eth0. Sep?20?01:45:36?srv4?Keepalived_vrrp:?VRRP_Instance(VI_1)?Sending?gratuitous?ARPs?on?eth0?for?192.168.8.100

通過ip a 命令可以看到192.168.8.100/24綁定到了eth0上

[root@srv4?bin]#?ip?a 1:?lo:?<LOOPBACK,UP,LOWER_UP>?mtu?16436?qdisc?noqueue?link/loopback?00:00:00:00:00:00?brd?00:00:00:00:00:00inet?127.0.0.1/8?scope?host?loinet6?::1/128?scope?host?valid_lft?forever?preferred_lft?forever 2:?eth0:?<BROADCAST,MULTICAST,UP,LOWER_UP>?mtu?1500?qdisc?pfifo_fast?qlen?1000link/ether?00:0c:29:50:2d:9d?brd?ff:ff:ff:ff:ff:ffinet?192.168.8.4/24?brd?192.168.8.255?scope?global?eth0inet?192.168.8.100/24?scope?global?secondary?eth0inet6?fe80::20c:29ff:fe50:2d9d/64?scope?link?valid_lft?forever?preferred_lft?forever

啟動備用節(jié)點B后的日志為:

Sep?20?01:47:31?hadoopsrv?Keepalived_vrrp:?Configuration?is?using?:?34262?Bytes Sep?20?01:47:31?hadoopsrv?Keepalived_vrrp:?VRRP_Instance(VI_1)?Entering?BACKUP?STATE Sep?20?01:47:31?hadoopsrv?Keepalived_vrrp:?VRRP?sockpool:?[ifindex(2),?proto(112),?fd(7,8)] Sep?20?01:47:31?hadoopsrv?Keepalived:?Starting?VRRP?child?process,?pid=20567

4,在兩臺機器上安裝tomcat,安裝步驟省略
安裝完成后在節(jié)點A的機器上創(chuàng)建一個html文件內(nèi)容如下

this?is?the?test?page <br> from?server?192.168.8.4

通過下面的url驗證能夠正常訪問
http://192.168.8.4:8080/test/test.html

安裝完成后在節(jié)點B的機器上創(chuàng)建一個html文件內(nèi)容如下

this?is?the?test?page <br> from?server?192.168.8.6

通過下面的url驗證能夠正常訪問
http://192.168.8.6:8080/test/test.html
在主節(jié)點,節(jié)點A正常的時候通過下面的url訪問
192.168.8.100:8080/test/test.html
返回的內(nèi)容應(yīng)該為主節(jié)點上的html

this?is?the?test?page <br> from?server?192.168.8.4

將節(jié)點A的keepalived停止: killall keepalived
通過下面的url訪問
192.168.8.100:8080/test/test.html
返回的內(nèi)容應(yīng)該為備用節(jié)點上的內(nèi)容

this?is?the?test?page <br> from?server?192.168.8.6

同時查看節(jié)點B的日志:發(fā)現(xiàn)節(jié)點B轉(zhuǎn)為主節(jié)點并且會廣播ARP消息

Sep?20?01:55:44?hadoopsrv?Keepalived_vrrp:?VRRP_Instance(VI_1)?Transition?to?MASTER?STATE Sep?20?01:55:45?hadoopsrv?Keepalived_vrrp:?VRRP_Instance(VI_1)?Entering?MASTER?STATE Sep?20?01:55:45?hadoopsrv?Keepalived_vrrp:?VRRP_Instance(VI_1)?setting?protocol?VIPs. Sep?20?01:55:45?hadoopsrv?Keepalived_vrrp:?VRRP_Instance(VI_1)?Sending?gratuitous?ARPs?on?eth0?for?192.168.8.100 Sep?20?01:55:45?hadoopsrv?avahi-daemon[3769]:?Registering?new?address?record?for?192.168.8.100?on?eth0. Sep?20?01:55:50?hadoopsrv?Keepalived_vrrp:?VRRP_Instance(VI_1)?Sending?gratuitous?ARPs?on?eth0?for?192.168.8.100

本文的目的主要是演示keepalived實現(xiàn)雙機熱備的功能和過程。
對于應(yīng)用本身(tomcat)發(fā)生錯誤,以及"腦裂"等問題是不能解決的。

轉(zhuǎn)載于:https://my.oschina.net/ydsakyclguozi/blog/515049

總結(jié)

以上是生活随笔為你收集整理的使用keepalived实现双机热备的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。