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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

linux 软件备份 主从,linux高可用(HA)keepalived 主从备份

發布時間:2023/12/20 linux 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 linux 软件备份 主从,linux高可用(HA)keepalived 主从备份 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

利用keepalived可以實現對linux服務器的高可用性,即主從備份,一臺線上服務器出故障另外一臺服務器頂替它,當出故障的服務器恢復時又自動轉換成主服務器,頂替它的服務器再次轉換為備胎,當主服務器宕機、主服務器網卡壞掉、甚至主服務器服務掛掉(要用腳本監控實現轉換)都可以自動切換到從服務器,下面針對這三種故障進行模擬。

實驗環境:2臺rhel5.6,keepalived-1.1.20.tar.gz

實驗過程:

本實驗以web服務為例,兩臺linux都安裝Apache服務。

配置yum源,做準備工作,因為本次模擬的是主從備份,所以除了keepalived配置文件有區別外其他配置均相同。在實驗前,將selinux和防火墻都關掉。

主服務器配置:

[root@web1_master ~]# yum install gcc gcc-c++ openssl-devel httpd kernel-devel -y

[root@web1_master ~]#?echo "master" > /var/www/html/index.html

[root@web1_master ~]#?tar zxf keepalived-1.1.20.tar.gz

[root@web1_master ~]#?cd keepalived-1.1.20/

#./configure --sysconf=/etc/ --with-kernel-dir=/usr/src/kernels/2.6.18-238.el5-i686/

#make &&make install

#cp /usr/local/sbin/keepalived /usr/sbin/

[root@web1_master ~]# cat /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {

notification_email {

acassen@firewall.loc

failover@firewall.loc

sysadmin@firewall.loc

}

notification_email_from Alexandre.Cassen@firewall.loc

smtp_server 192.168.200.1

smtp_connect_timeout 30

router_id LVS_DEVEL

}

vrrp_instance VI_1 {

state MASTER

interface eth0

virtual_router_id 51

priority 100

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.65.65

}

}

####將keepalived.conf配置文件修改成以上配置,即修改虛擬地址為192.168.65.65,這個虛擬地址是虛擬不存在的,用戶在訪問網頁的時候訪問的就是這個虛擬地址,本配置文件要注意修改服務器的主從狀態、優先級、組id以及虛擬ip,還可以修改Email地址通知自己等。

#?service keepalived start

#?service httpd start

# chkconfig --add httpd

#?chkconfig --add keepalived

#?chkconfig httpd on

#?chkconfig keepalived on

從服務器配置:

[root@web1_slave keepalived]# cat /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {

notification_email {

acassen@firewall.loc

failover@firewall.loc

sysadmin@firewall.loc

}

notification_email_from Alexandre.Cassen@firewall.loc

smtp_server 192.168.200.1

smtp_connect_timeout 30

router_id LVS_DEVEL

}

vrrp_instance VI_1 {

state BACKUP

interface eth0

virtual_router_id 51

priority 90

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.65.65

}

}

#####從服務器keepalived.conf的主配置文件,優先級改為比主的優先級(100)小,這里是90.

# echo "slave" > /var/www/html/index.html

######其他配置內容和主服務器相同

當主服務器宕機或是網卡出問題,從服務器都會取代它變成主服務器

上圖是當主服務器網卡重啟時,在從服務器日志記錄上顯示從服務器先是切換成主服務器,后又切換成從服務器。

當web站點掛了時,還想讓從服務器自動切換成主服務器就需要腳本來執行。

下面新建一個腳本,名叫check_httpd.sh ,其位置都放在主從服務器的/etc/keepalived/下面,(主從服務器使用相同的腳本,腳本放的位置也都相同,在keepalived.conf修改的地方、內容也都相同)

下面是check_httpd.sh 腳本的內容

[root@web1_master keepalived]# cat check_httpd.sh

#!/bin/bash

CHECK_TIME=2

check()

{

curl http://127.0.0.1/ >/dev/null 2>&1

ret=$?

if [ $ret -ne 0 ];then

return $ret;

fi

}

while [ $CHECK_TIME -ne 0 ]

do

let "CHECK_TIME -= 1"

check

HTTP_OK=$?

if [ $HTTP_OK -eq 0 ];then

exit 0

fi

if [ $HTTP_OK -ne 0 ] && ?[ $CHECK_TIME -eq 0 ]

then

exit 1

fi

done

修改主服務器keepalived.conf配置文件,結果如下:

[root@web1_master keepalived]# cat keepalived.conf

! Configuration File for keepalived

global_defs {

notification_email {

acassen@firewall.loc

failover@firewall.loc

sysadmin@firewall.loc

}

notification_email_from Alexandre.Cassen@firewall.loc

smtp_server 192.168.200.1

smtp_connect_timeout 30

router_id LVS_DEVEL

}

vrrp_script check_http {

script "/etc/keepalived/check_httpd.sh"

weight -5

interval 1

}

vrrp_instance VI_1 {

state MASTER

interface eth0

virtual_router_id 51

priority 100

advert_int 1

track_script {

check_http

}

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.65.65

}

}

修改從服務器keepalived.conf配置文件,結果如下:

[root@web1_slave keepalived]# cat keepalived.conf

! Configuration File for keepalived

global_defs {

notification_email {

acassen@firewall.loc

failover@firewall.loc

sysadmin@firewall.loc

}

notification_email_from Alexandre.Cassen@firewall.loc

smtp_server 192.168.200.1

smtp_connect_timeout 30

router_id LVS_DEVEL

}

vrrp_script check_http {

script "/etc/keepalived/check_httpd.sh"

weight -5

interval 1

}

vrrp_instance VI_1 {

state BACKUP

interface eth0

virtual_router_id 51

priority 90

advert_int 1

track_script {

check_http

}

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.65.65

}

}

分別重啟兩臺服務器的keepalived服務

#service keepalivedrestart

到這里,如果主服務器的web程序出現故障,則從服務器會在1秒鐘后自動切換成主服務器,當主服務器恢復時,從服務器會自動切換成備胎,主服務器依然是主服務器。

至此,linux高可用性(HA_keepalived)配置完成。

總結

以上是生活随笔為你收集整理的linux 软件备份 主从,linux高可用(HA)keepalived 主从备份的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。