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 主从备份的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 网页验证码识别实例VB.NET2019(
- 下一篇: 低压差线性稳压器简介