這篇文章主要為大家展示了“MySQL高可用之keepalived方案的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“MySQL高可用之keepalived方案的示例分析”這篇文章吧。
成都創(chuàng)新互聯(lián)公司專注于二道江企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站設(shè)計(jì),成都做商城網(wǎng)站。二道江網(wǎng)站建設(shè)公司,為二道江等地區(qū)提供建站服務(wù)。全流程定制設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)
實(shí)驗(yàn)環(huán)境
mysql master : 192.168.111.52
mysql slave : 192.168.111.53
keepalived vip : 192.168.111.60
、搭建過程
1. mysql雙主的構(gòu)建
① 互相 change master 即可,此處省略該過程,著重講下keepalived
2. keepalived相關(guān)
① yum -y install keepalived 安裝keepalived
② root@192.168.111.52:~# keepalived -v
Keepalived v1.2.7 (02/21,2013)
③ 編輯 /etc/keepalived/keepalived.conf
點(diǎn)擊(此處)折疊或打開
root@192.168.111.52:keepalived# cat keepalived.conf
! Configuration File for keepalived
global_defs {##全局配置
notification_email {
horand_gc@163.com #####郵件接收者
}
notification_email_from dba@163.com #####郵件發(fā)送者
smtp_server smtp.163.com #####SMTP服務(wù)器
smtp_connect_timeout 30
router_id haMySQL #####routerID 同一組keepalived設(shè)置為相同
}
vrrp_script chk_mysql {##健康檢測(cè)相關(guān)配置
script "/etc/keepalived/chk_mysql.sh" #####設(shè)置腳本 或者直命令 返回 0 則表示成功 >0 則表示失敗, 詳情可以后面的腳本內(nèi)容
interval 1 #####檢測(cè)間隔
weight 2 #####檢測(cè)返回失敗之后優(yōu)先級(jí)會(huì)減少 2 (如果 master優(yōu)先級(jí)100 , slave 優(yōu)先級(jí) 99 ,master檢測(cè)失敗則優(yōu)先級(jí)為100-2 < 99 ,則slave會(huì)提升為主)
}
vrrp_instance VI_1 {
state MASTER ##### 設(shè)為master
interface eth2 ##### 網(wǎng)卡設(shè)定
virtual_router_id 51 ##### 針對(duì)該 instance的虛擬id , 同一組 instance設(shè)置相同
priority 100 ##### 優(yōu)先級(jí)設(shè)定
advert_int 1 ##### 檢測(cè)時(shí)間間隔
authentication {
auth_type PASS ##### 同一組instance之間的認(rèn)證方式為 PASS ,pass 為7777 ,必須相同(防止 有用戶惡意偽造 vrrp)
auth_pass 7777
}
virtual_ipaddress {
192.168.111.60 ##### 設(shè)置虛擬ip ,可以設(shè)置多個(gè)
}
track_script {
chk_mysql ##### 表示該instance 使用chk_mysql進(jìn)行相關(guān)檢測(cè)
}
##### 以下配置 在該實(shí)例 轉(zhuǎn)換為 master,slave,或者出錯(cuò)的時(shí)候執(zhí)行的腳本(可以設(shè)置郵件通知,或者處理一些其他問題)
# notify_master "/etc/keepalived/change_master.sh"
# notify_slave "/etc/keepalived/change_slave.sh"
# notify_fault "/etc/keepalived/change_fault.sh"
}
root@192.168.111.53:keepalived# cat keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
horand_gc@163.com
}
notification_email_from dba@163.com
smtp_server smtp.163.com
smtp_connect_timeout 30
router_id haMySQL
}
vrrp_script chk_mysql {
script "/etc/keepalived/chk_mysql.sh"
interval 1
weight 2
}
vrrp_instance VI_1 {
state BACKUP ##### 該主機(jī)作為備機(jī) BACKUP
interface eth2
virtual_router_id 51
priority 99 ##### 優(yōu)先級(jí)設(shè)置 小于 master
advert_int 1
authentication {
auth_type PASS
auth_pass 7777
}
virtual_ipaddress {
192.168.111.60
}
track_script {
chk_mysql
}
}
root@192.168.111.52:keepalived# cat chk_mysql.sh
#!/bin/bash
num=`ps -ef |grep mysqld | grep -v grep | wc -l` ##### 查看mysqld進(jìn)程數(shù)量 , 正常情況有一個(gè)root起的mysqld_safe守護(hù)進(jìn)程,還有一個(gè)屬于mysql用戶的mysqld進(jìn)程
[[ $num -eq 2 ]] && exit 0 || exit 1
3. 故障模擬
① 啟動(dòng) keepalived
點(diǎn)擊(此處)折疊或打開
root@192.168.111.52:keepalived# tail /var/log/messages
Apr 29 13:45:24 localhost Keepalived_healthcheckers[24184]: Registering Kernel netlink command channel
Apr 29 13:45:24 localhost Keepalived_healthcheckers[24184]: Opening file '/etc/keepalived/keepalived.conf'.
Apr 29 13:45:24 localhost Keepalived_healthcheckers[24184]: Configuration is using : 7417 Bytes
Apr 29 13:45:24 localhost Keepalived_vrrp[24185]: Opening file '/etc/keepalived/keepalived.conf'.
Apr 29 13:45:24 localhost Keepalived_vrrp[24185]: Configuration is using : 65552 Bytes
Apr 29 13:45:24 localhost Keepalived_vrrp[24185]: Using LinkWatch kernel netlink reflector...
Apr 29 13:45:24 localhost Keepalived_healthcheckers[24184]: Using LinkWatch kernel netlink reflector...
Apr 29 13:45:25 localhost Keepalived_vrrp[24185]: VRRP_Script(chk_mysql) succeeded
Apr 29 13:45:25 localhost Keepalived_vrrp[24185]: VRRP_Instance(VI_1) Transition to MASTER STATE
Apr 29 13:45:26 localhost Keepalived_vrrp[24185]: VRRP_Instance(VI_1) Entering MASTER STATE
root@192.168.111.53:keepalived# tailf /var/log/messages
Apr 29 13:49:27 localhost Keepalived_healthcheckers[32569]: Registering Kernel netlink reflector
Apr 29 13:49:27 localhost Keepalived_healthcheckers[32569]: Registering Kernel netlink command channel
Apr 29 13:49:27 localhost Keepalived_vrrp[32570]: Opening file '/etc/keepalived/keepalived.conf'.
Apr 29 13:49:27 localhost Keepalived_vrrp[32570]: Configuration is using : 65550 Bytes
Apr 29 13:49:27 localhost Keepalived_vrrp[32570]: Using LinkWatch kernel netlink reflector...
Apr 29 13:49:27 localhost Keepalived_healthcheckers[32569]: Opening file '/etc/keepalived/keepalived.conf'.
Apr 29 13:49:27 localhost Keepalived_healthcheckers[32569]: Configuration is using : 7415 Bytes
Apr 29 13:49:27 localhost Keepalived_vrrp[32570]: VRRP_Instance(VI_1) Entering BACKUP STATE
Apr 29 13:49:27 localhost Keepalived_healthcheckers[32569]: Using LinkWatch kernel netlink reflector...
Apr 29 13:49:27 localhost Keepalived_vrrp[32570]: VRRP_Script(chk_mysql) succeeded
ip a 可以查看到 vip 192.168.111.60 在 192.168.111.52(master)上
② 關(guān)閉 111.52上面的mysql
點(diǎn)擊(此處)折疊或打開
root@192.168.111.52:keepalived# mysqladmin shutdown
root@192.168.111.52:keepalived# tailf /var/log/messages
Apr 29 14:19:30 localhost Keepalived_vrrp[24862]: VRRP_Script(chk_mysql) failed
Apr 29 14:19:32 localhost Keepalived_vrrp[24862]: VRRP_Instance(VI_1) Received higher prio advert
Apr 29 14:19:32 localhost Keepalived_vrrp[24862]: VRRP_Instance(VI_1) Entering BACKUP STATE
root@192.168.111.53:keepalived# tailf /var/log/messages
Apr 29 14:19:55 localhost Keepalived_vrrp[566]: VRRP_Instance(VI_1) forcing a new MASTER election
Apr 29 14:19:56 localhost Keepalived_vrrp[566]: VRRP_Instance(VI_1) Transition to MASTER STATE
Apr 29 14:19:57 localhost Keepalived_vrrp[566]: VRRP_Instance(VI_1) Entering MASTER STATE
ip a 可以查看到 vip 192.168.111.60 在 192.168.111.53(master)上
③ 啟動(dòng)111.52上面的mysql
點(diǎn)擊(此處)折疊或打開
root@192.168.111.52:keepalived# mysqld_safe & ; tailf /var/log/messages
Apr 29 14:24:21 localhost Keepalived_vrrp[24862]: VRRP_Script(chk_mysql) succeeded
Apr 29 14:24:22 localhost Keepalived_vrrp[24862]: VRRP_Instance(VI_1) forcing a new MASTER election
Apr 29 14:24:23 localhost Keepalived_vrrp[24862]: VRRP_Instance(VI_1) Transition to MASTER STATE
Apr 29 14:24:24 localhost Keepalived_vrrp[24862]: VRRP_Instance(VI_1) Entering MASTER STATE
root@192.168.111.53:keepalived# tailf /var/log/messages
Apr 29 14:24:45 localhost Keepalived_vrrp[566]: VRRP_Instance(VI_1) Received higher prio advert
Apr 29 14:24:45 localhost Keepalived_vrrp[566]: VRRP_Instance(VI_1) Entering BACKUP STATE
ip a 可以查看到 vip 192.168.111.60 在 192.168.111.52(master)上,也就是說111.52會(huì)持續(xù)通過track_script的腳本檢查 ,若成功的話會(huì)恢復(fù)原來的優(yōu)先級(jí)100 ,便把vip搶過來了(若不希望優(yōu)先級(jí)高的直接上來直接搶占vip的話 需要再instance 里面配置 nopreempt ,backup無需設(shè)置)
虛擬server
以上是實(shí)驗(yàn)是通過 vrrp_script以及trace_script 實(shí)現(xiàn)優(yōu)先級(jí)變換來實(shí)現(xiàn)故障轉(zhuǎn)移的,現(xiàn)在看下 通過虛擬server怎么實(shí)現(xiàn)mysql的高可用
① 配置
點(diǎn)擊(此處)折疊或打開
root@192.168.111.52:keepalived# cat /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
tab@taomee.com
}
notification_email_from dba@taomee.com
smtp_server smtp.shidc.taomee.com
smtp_connect_timeout 30
router_id haMySQL
}
vrrp_script chk_mysql {
script "/etc/keepalived/chk_mysql.sh"
interval 1
weight 2
}
vrrp_instance VI_1 {
state MASTER
interface eth2
virtual_router_id 51
priority 100
nopreempt
advert_int 1
authentication {
auth_type PASS
auth_pass 7777
}
virtual_ipaddress {
192.168.111.60
}
# track_script {
# chk_mysql
# }
}
virtual_server 192.168.111.60 3306 {
delay_loop 6
persistence_timeout 300
protocol TCP
real_server 192.168.111.52 3306 {
weight 1
notify_down /etc/keepalived/kill_self.sh
TCP_CHECK {
tcp_port 3306
connect_timeout 3
}
}
}
root@192.168.111.53:keepalived# cat /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
tab@taomee.com
}
notification_email_from dba@taomee.com
smtp_server smtp.shidc.taomee.com
smtp_connect_timeout 30
router_id haMySQL
}
vrrp_script chk_mysql {
script "/etc/keepalived/chk_mysql.sh"
interval 1
weight 2
}
vrrp_instance VI_1 {
state BACKUP
interface eth2
virtual_router_id 51
priority 99
advert_int 1
authentication {
auth_type PASS
auth_pass 7777
}
virtual_ipaddress {
192.168.111.60
}
# track_script { #########這里先注釋掉 通過追蹤腳本的檢查
# chk_mysql
# }
}
virtual_server 192.168.111.60 3306 {
delay_loop 6
persistence_timeout 300
protocol TCP
real_server 192.168.111.53 3306 {### 真實(shí) 服務(wù)
weight 1 #### 權(quán)重,用來多真實(shí)服務(wù) 均衡使用
notify_down /etc/keepalived/kill_self.sh ####在檢查該服務(wù)不可用時(shí)執(zhí)行該腳本(用來殺死 keepalived 實(shí)現(xiàn) vip 飄逸)
TCP_CHECK {
tcp_port 3306 #### 檢查端口 繼承 real_server 192.168.111.53 3306 {### 真實(shí) 服務(wù)
connect_timeout 3 #### tcp超時(shí)時(shí)間
}
}
}
root@192.168.111.53:keepalived# cat /etc/keepalived/kill_self.sh
#!/bin/bash
killall keepalived
②啟動(dòng)keepalived
點(diǎn)擊(此處)折疊或打開
root@192.168.111.52:keepalived# keepalived
root@192.168.111.52:keepalived# tailf /var/log/messages
Apr 29 14:48:22 localhost Keepalived_vrrp[20482]: Opening file '/etc/keepalived/keepalived.conf'.
Apr 29 14:48:22 localhost Keepalived_vrrp[20482]: Configuration is using : 64590 Bytes
Apr 29 14:48:22 localhost Keepalived_vrrp[20482]: Using LinkWatch kernel netlink reflector...
Apr 29 14:48:22 localhost Keepalived_healthcheckers[20481]: IPVS: Scheduler not found
Apr 29 14:48:22 localhost kernel: IPVS: Scheduler module ip_vs_ not found
Apr 29 14:48:22 localhost Keepalived_healthcheckers[20481]: IPVS: Service not defined
Apr 29 14:48:22 localhost Keepalived_healthcheckers[20481]: Using LinkWatch kernel netlink reflector...
Apr 29 14:48:22 localhost Keepalived_healthcheckers[20481]: Activating healthchecker for service [192.168.111.52]:3306
Apr 29 14:48:23 localhost Keepalived_vrrp[20482]: VRRP_Instance(VI_1) Transition to MASTER STATE
Apr 29 14:48:24 localhost Keepalived_vrrp[20482]: VRRP_Instance(VI_1) Entering MASTER STATE
root@192.168.111.53:keepalived# keepalived
root@192.168.111.53:keepalived# tailf /var/log/messages
Apr 29 14:48:51 localhost Keepalived_healthcheckers[25092]: Configuration is using : 11673 Bytes
Apr 29 14:48:51 localhost Keepalived_vrrp[25093]: Opening file '/etc/keepalived/keepalived.conf'.
Apr 29 14:48:51 localhost Keepalived_vrrp[25093]: Configuration is using : 64568 Bytes
Apr 29 14:48:51 localhost Keepalived_vrrp[25093]: Using LinkWatch kernel netlink reflector...
Apr 29 14:48:51 localhost Keepalived_vrrp[25093]: VRRP_Instance(VI_1) Entering BACKUP STATE
Apr 29 14:48:51 localhost kernel: IPVS: Scheduler module ip_vs_ not found
Apr 29 14:48:51 localhost Keepalived_healthcheckers[25092]: IPVS: Scheduler not found
Apr 29 14:48:51 localhost Keepalived_healthcheckers[25092]: IPVS: Service not defined
Apr 29 14:48:51 localhost Keepalived_healthcheckers[25092]: Using LinkWatch kernel netlink reflector...
Apr 29 14:48:51 localhost Keepalived_healthcheckers[25092]: Activating healthchecker for service [192.168.111.53]:3306
此時(shí) ip a 命令可以查看虛擬ip 111.60 在111.52(master) 上
③關(guān)閉 111.52上的mysql
點(diǎn)擊(此處)折疊或打開
root@192.168.111.52:keepalived# mysqladmin shutdown
2017-04-29T07:07:38.121123Z mysqld_safe mysqld from pid file /opt/mysql/mysqld.pid ended
[1]+ Done mysqld_safe
root@192.168.111.52:keepalived# tailf /var/log/messages
Apr 29 15:07:31 localhost Keepalived_healthcheckers[23405]: TCP connection to [192.168.111.52]:3306 failed !!!
Apr 29 15:07:31 localhost Keepalived_healthcheckers[23405]: Removing service [192.168.111.52]:3306 from VS [192.168.111.60]:3306
Apr 29 15:07:31 localhost Keepalived_healthcheckers[23405]: IPVS: Service not defined
Apr 29 15:07:31 localhost Keepalived_healthcheckers[23405]: Executing [/etc/keepalived/kill_self.sh] for service [192.168.111.52]:3306 in VS [192.168.111.60]:3306
Apr 29 15:07:31 localhost Keepalived_healthcheckers[23405]: Lost quorum 1-0=1 > 0 for VS [192.168.111.60]:3306
Apr 29 15:07:31 localhost Keepalived_healthcheckers[23405]: Remote SMTP server [0.0.0.0]:25 connected.
Apr 29 15:07:31 localhost Keepalived[23404]: Stopping Keepalived v1.2.7 (02/21,2013)
Apr 29 15:07:31 localhost Keepalived_healthcheckers[23405]: IPVS: No such service
Apr 29 15:07:31 localhost Keepalived_vrrp[23406]: VRRP_Instance(VI_1) sending 0 priority
root@192.168.111.53:keepalived# tailf /var/log/messages
Apr 29 15:07:32 localhost Keepalived_vrrp[26815]: VRRP_Instance(VI_1) Transition to MASTER STATE
Apr 29 15:07:33 localhost Keepalived_vrrp[26815]: VRRP_Instance(VI_1) Entering MASTER STATE
此時(shí) ip a 命令可以看到虛擬ip 111.60在111.53(新master)上
以上是“MySQL高可用之keepalived方案的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!