【MySQL】keepalived+haproxy實現mysql的高可用與負載均衡
⒈haproxy檢測mysql(難點)
具體方法:將檢測指令碼提供給xinnetd管理,提供tcp埠(本人採用埠6033)
在/etc/xinetd.d下,建立mysqlchk檔案
[root@gz-22 xinetd.d]# pwd
/etc/xinetd.d
[root@gz-22 xinetd.d]# ls -l mysqlchk
-rw-r--r-- 1 root root 370 Jun 2 13:55 mysqlchk
[root@gz-22 xinetd.d]#
mysql檔案內容如下:
service mysqlcheck
{
disable = no
flags = REUSE
socket_type = stream
port = 6033
wait = no
user = root
server = /usr/local/etc/mysqlchk_status.sh#此為提供給xinetd管理的指令碼
log_type = FILE /dev/null
log_on_failure += USERID
only_from = 192.168.0.0/24
}
Mysqlchk_status.sh檢測mysql狀態的指令碼如下:
[root@gz-22 etc]# more mysqlchk_status.sh
#!/bin/bash
MYSQL_HOST="192.168.0.13"
MYSQL_PORT="3306"
MYSQL_USERNAME="root"
MYSQL_PASSWORD="tianqu"
MYSQL_PATH=mysql #特別注意,這裡的指令碼要採用絕對路徑,本人排錯一天時間
STATUS=`$MYSQL_PATH -u$MYSQL_USERNAME -p$MYSQL_PASSWORD -h${MYSQL_HOST} -e "REPAIR TABLE mysql.time_zone\G" 2>/dev/null |awk '/Msg_text/{print $2}'`
if [ "$STATUS" = "OK" ];then
# mysql is fine, return http 200
/bin/echo -e "HTTP/1.1 200 OK\r\n"
/bin/echo -e "Content-Type: Content-Type: text/plain\r\n"
/bin/echo -e "\r\n"
/bin/echo -e "MySQL ($MYSQL_HOST:$MYSQL_PORT) replication is running.\r\n"
/bin/echo -e "\r\n"
else
# mysql is down, return http 503
/bin/echo -e "HTTP/1.1 503 Service Unavailable\r\n"
/bin/echo -e "Content-Type: Content-Type: text/plain\r\n"
/bin/echo -e "\r\n"
/bin/echo -e "MySQL ($MYSQL_HOST:$MYSQL_PORT) replication is *down*.\r\n"
/bin/echo -e "\r\n"
fi
[root@gz-22 etc]#
啟動xinetd服務,為讓配置生效
[root@gz-22 etc]# /etc/init.d/xinetd restart
我們檢視6033埠是否生效
[root@gz-22 etc]# curl -I http://192.168.0.13:6033
HTTP/1.1 200 OK
[root@gz-22 etc]#
也可以用telnet測試,如下:
[root@gz-22 etc]# curl -I http://192.168.0.13:6033
HTTP/1.1 200 OK
[root@gz-22 etc]# telnet 192.168.0.13 6033
Trying 192.168.0.13...
Connected to 192.168.0.13.
Escape character is '^]'.
HTTP/1.1 200 OK
Content-Type: Content-Type: text/plain
MySQL (192.168.0.13:3306) replication is running.
Connection closed by foreign host.
[root@gz-22 etc]#
如出現HTTP/1.1 200 OK字樣則表示ok
⒉Haproxy配置
[root@gz-22 etc]# more /usr/local/haproxy/etc/haproxy.conf
global
log 127.0.0.1 local0 info
maxconn 10000
daemon
# ulimit-n 65536
chroot /usr/local/haproxy
pidfile /usr/local/haproxy/run/haproxy.pid
user haproxy
group haproxy
defaults
mode http
option dontlognull
retries 3
option redispatch
maxconn 10000
contimeout 5000
clitimeout 30000
srvtimeout 30000
listen admin_stats
# stats hide-version
bind 0.0.0.0:8082
mode http
stats uri /status
stats realm Global\ statistics
stats auth test:987(*&
listen 8684.cn-Msql-proxy 192.168.0.222:3307
mode tcp
balance roundrobin
option httpchk OPTIONS * HTTP/1.1\n200
server db112 192.168.0.13:3306 weight 1 check port 6033 inter 5s rise 2 fall 2
#埠6033即為上面xinetd定義的埠
server db125 192.168.0.3:3306 weight 1 check port 6033 inter 5s rise 2 fall 2
[root@gz-22 etc]#
3.Keepalived的配置
vrrp_script chk_haproxy {
script "/usr/local/etc/check_haproxy.sh" # cheaper than pidof
interval 2 # check every 2 seconds
weight 2
}
vrrp_instance VI_1 {
interface br0
state MASTER
virtual_router_id 233
priority 100
virtual_ipaddress {
192.168.0.222/24 dev eth1 label eth1:1
}
track_script {
chk_haproxy # +2 if process is present
}
notify_backup "/etc/init.d/haproxy stop"
notify_master "/etc/init.d/haproxy start"
}
關於vrrp_script的weight值,官方沒有文件可供參考,但是本人透過測試
vrrp_script在執行時,就會改變priority的值
Jun 5 14:26:49 node1 Keepalived_vrrp[3848]: VRRP_Script(chk_haproxy) succeeded
例如:主第一次啟動時,就會改變優先順序及priority=weight+priority,以後每interval間隔時間都會做這樣一個優先順序的累加。所以當你配置vrrp_script不生效時,你的考慮下vrrp設定是否正確
Vrrp_script中的指令碼:
[root@node1 ~]# more /usr/local/etc/check_haproxy.sh
#!/bin/bash
sleep 1
REL=`/usr/bin/curl -I -s -u test:987\(*\& http://192.168.0.3:8082/status |head -n1|awk '{print $2}'`
if [ -z "$REL" ] || [ "$REL" -ne 200 ];then
exit 1
else
exit 0
fi
[root@node1 ~]#
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30221425/viewspace-1690180/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- keepalived+haproxy實現mysql負載均衡高可用MySql負載
- HaProxy 實現 MySQL 負載均衡MySql負載
- Keepalived實現Nginx負載均衡高可用Nginx負載
- LVS+Keepalived 實現高可用負載均衡負載
- haporxy+keepalived實現負載均衡+高可用負載
- keepalived高可用負載均衡負載
- Nginx負載均衡高可用Nginx負載
- 基於MySQL Cluster + LVS + KeepAlived部署負載均衡高可用架構MySql負載架構
- LVS+Keepalive 實現負載均衡高可用叢集負載
- Nginx實現請求的負載均衡 + keepalived實現Nginx的高可用Nginx負載
- CentOS7 實現 Keepalived + Nginx 實現高可用 Web 負載均衡CentOSNginxWeb負載
- 【DB寶42】MySQL高可用架構MHA+ProxySQL實現讀寫分離和負載均衡MySql架構負載
- Mycat實現mysql的負載均衡讀寫分離MySql負載
- mysql負載均衡搭建(haproxy)MySql負載
- 【Nginx】如何實現Nginx的高可用負載均衡?看完我也會了!!Nginx負載
- windows NLB+ARR實現Web負載均衡高可用/可伸縮的方法WindowsWeb負載
- 技術|如何為MySQL MGR實現簡單的負載均衡代理?MySql負載
- keepalived+MySQL實現高可用MySql
- MySQL高可用架構:mysql+keepalived實現MySql架構
- nginx反向大理和負載均衡以及高可用Nginx負載
- Mycat 雙主雙從-負載均衡-高可用負載
- Haproxy+Keepalived高可用負載均衡叢集負載
- Nginx 高階篇(三)負載均衡的實現Nginx負載
- DockerCompose編排Nginx+Mysql並實現Nginx配置Mysql(TCP協議)負載均衡DockerNginxMySqlTCP協議負載
- MHA+MySQL主從配置實現MySQL高可用MySql
- 【Nginx】如何使用Nginx實現MySQL資料庫的負載均衡?看完我懂了!!NginxMySql資料庫負載
- 如何設計和實現高可用的MySQLMySql
- Ribbon實現負載均衡負載
- GRPC 負載均衡實現RPC負載
- nginx實現負載均衡Nginx負載
- haproxy(單機)+mysql叢集負載均衡MySql負載
- LVS#MySQL+Keepalived四層負載均衡MySql負載
- 如何設計和實現高可用MySQLMySql
- MySQL 實現高可用架構之 MHAMySql架構
- Nginx 動靜分離與負載均衡的實現Nginx負載
- MySQL Route負載均衡與讀寫分離Docker環境使用MySql負載Docker
- 3.RabbitMQ高階叢集搭建(Haproxy負載均衡、Keepalived高可用)MQ負載
- 淺談負載均衡演算法與實現負載演算法
- Keepalived+Nginx+Tomcat配置高可用負載均衡系統示例NginxTomcat負載