mysql+keepalived主从切换脚本 转

时间:2022-03-04 00:33:35

Keepalived MySQL故障自动切换脚本

 

MySQL架构为master-slave(主从),master故障自动切换到slave上。当然也可以设置为双master,但这里有个弊端:就是当主的压力很大时,从上延时很大,比如落后2000秒,此时主挂了,从接管(VIP漂移到从),用户刚才发表的文章,此时因为同步延时大,还没复制过来,于是用户又发表了一篇文章,当原来的master修好后,因从的IO和SQL线程还在开启状态,还会继续同步刚才没有同步复制完的数据,这时有可能把用户新发表的文章更改掉,造成用户数据丢失。

考虑到这种情况,我这里还是用的master-slave(主从)架构。

keepalive安装很简单,这里不再啰嗦。主要看下配置文件和脚本:


  1. # more /etc/keepalived/keepalived.conf

  2. global_defs {

  3. router_id KeepAlive_Mysql

  4. }

  5. vrrp_script check_run {

  6. script "/root/sh/mysql_check.sh"

  7. interval 300

  8. }

  9. vrrp_sync_group VG1 {

  10. group {

  11. VI_1

  12. }

  13. }

  14. vrrp_instance VI_1 {

  15. state BACKUP

  16. interface eth0

  17. virtual_router_id 51

  18. priority 100

  19. advert_int 1

  20. nopreempt

  21. authentication {

  22. auth_type PASS

  23. auth_pass 1111

  24. }

  25. track_script {

  26. check_run

  27. }

  28. notify_master /root/sh/master.sh

  29. notify_backup /root/sh/backup.sh

  30. notify_stop /root/sh/stop.sh

  31. virtual_ipaddress {

  32. 192.168.8.150

  33. }

  34. }

notify_master <STRING>|<QUOTED-STRING>    # 状态改变为MASTER后执行的脚本
notify_backup <STRING>|<QUOTED-STRING> # 状态改变为BACKUP后执行的脚本
notify_fault <STRING>|<QUOTED-STRING> # 状态改变为FAULT后执行的脚本
notify_stop <STRING>|<QUOTED-STRING> # VRRP停止后后执行的脚本
notify <STRING>|<QUOTED-STRING> # (1)任意状态改变后执行的脚本

下面解释下这4个脚本的用法:

mysql_check.sh(健康检查脚本,当发现mysql连接不上,会把keepalive进程关闭,并切换。)

  1. # more mysql_check.sh

  2. #!/bin/bash

  3. . /root/.bash_profile

  4. count=1

  5. while true

  6. do

  7. mysql -e "show status;" > /dev/null 2>&1

  8. i=$?

  9. ps aux | grep mysqld | grep -v grep > /dev/null 2>&1

  10. j=$?

  11. if [ $i = 0 ] && [ $j = 0 ]

  12. then

  13. exit 0

  14. else

  15. if [ $i = 1 ] && [ $j = 0 ]

  16. then

  17. exit 0

  18. else

  19. if [ $count -gt 5 ]

  20. then

  21. break

  22. fi

  23. let count++

  24. continue

  25. fi

  26. fi

  27. done

  28. /etc/init.d/keepalived stop

master.sh(状态改变为MASTER后执行的脚本)  (首先判断同步复制是否执行完毕,如果未执行完毕,等1分钟后,不论是否执行完毕,都跳过,并停止同步复制进程。) (其次,更改前端程序连接的业务账号admin的权限和密码,并记录当前切换以后的日志和POS点。)

  1. # more master.sh

  2. #!/bin/bash

  3. . /root/.bash_profile

  4. Master_Log_File=$(mysql -e "show slave status\G" | grep -w Master_Log_File | awk -F": " '{print $2}')

  5. Relay_Master_Log_File=$(mysql -e "show slave status\G" | grep -w Relay_Master_Log_File | awk -F": " '{print $2}')

  6. Read_Master_Log_Pos=$(mysql -e "show slave status\G" | grep -w Read_Master_Log_Pos | awk -F": " '{print $2}')

  7. Exec_Master_Log_Pos=$(mysql -e "show slave status\G" | grep -w Exec_Master_Log_Pos | awk -F": " '{print $2}')

  8. i=1

  9. while true

  10. do

  11. if [ $Master_Log_File = $Relay_Master_Log_File ] && [ $Read_Master_Log_Pos -eq $Exec_Master_Log_Pos ]

  12. then

  13. echo "ok"

  14. break

  15. else

  16. sleep 1

  17. if [ $i -gt 60 ]

  18. then

  19. break

  20. fi

  21. continue

  22. let i++

  23. fi

  24. done

  25. mysql -e "stop slave;"

  26. mysql -e "flush logs;GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%' IDENTIFIED BY 'admin';flush privileges;"

  27. mysql -e "show master status;" > /tmp/master_status_$(date "+%y%m%d-%H%M").txt

backup.sh(状态改变为BACKUP后执行的脚本)

  1. # more backup.sh

  2. #!/bin/bash

  3. . /root/.bash_profile

  4. mysql -e "GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%' IDENTIFIED BY '1q2w3e4r';flush privileges;"

stop.sh(keepalived停止后后执行的脚本) (首先把admin密码更改掉) (其次,设置参数,保证不丢失数据) (最后,查看是否还有写操作,不论是否执行完毕,1分钟后都退出。)

  1. # more stop.sh

  2. #!/bin/bash

  3. . /root/.bash_profile

  4. mysql -e "GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%' IDENTIFIED BY '1q2w3e4r';flush privileges;"

  5. mysql -e "set global innodb_support_xa=1;"

  6. mysql -e "set global sync_binlog=1;"

  7. mysql -e "set global innodb_flush_log_at_trx_commit=1;"

  8. M_File1=$(mysql -e "show master status\G" | awk -F': ' '/File/{print $2}')

  9. M_Position1=$(mysql -e "show master status\G" | awk -F': ' '/Position/{print $2}')

  10. sleep 1

  11. M_File2=$(mysql -e "show master status\G" | awk -F': ' '/File/{print $2}')

  12. M_Position2=$(mysql -e "show master status\G" | awk -F': ' '/Position/{print $2}')

  13. i=1

  14. while true

  15. do

  16. if [ $M_File1 = $M_File2 ] && [ $M_Position1 -eq $M_Position2 ]

  17. then

  18. echo "ok"

  19. break

  20. else

  21. sleep 1

  22. if [ $i -gt 60 ]

  23. then

  24. break

  25. fi

  26. continue

  27. let i++

  28. fi

  29. done

mysql+keepalived主从切换脚本 转的更多相关文章

  1. MySQL数据库主从切换脚本自动化

    MySQL数据库主从切换脚本自动化 本文转载自:https://blog.csdn.net/weixin_36135773/article/details/79514507 在一些实际环境中,如何实现 ...

  2. Spring AOP实现Mysql数据库主从切换(一主多从)

    设置数据库主从切换的原因:数据库中经常发生的是“读多写少”,这样读操作对数据库压力比较大,通过采用数据库集群方案, 一个数据库是主库,负责写:其他为从库,负责读,从而实现读写分离增大数据库的容错率.  ...

  3. nginx keepalived 主从切换

    注:  LVS + Keepalived  不知道为什么出现一个很郁闷的问题....... ------------------------------------------------------ ...

  4. Keepalived与MySQL互为主从自动切换配置

    为解决Mysql数据库单点问题,实现两台MySQL数据库互为主备,双向replication.当一Master出现问题,则将Slave切换为Master继续工作. 环境说明 系统版本:CentOS L ...

  5. mysql传统主从、双主复制&plus;keepalived配置步骤

    mysql主从.主主复制(双主复制)配置步骤 一:MySQL复制: MySQL复制简介: 将master服务器中主数据库的ddl和dml操作通过二进制日志传到slaves服务器上,然后在master服 ...

  6. KeepAlived&plus;MySQL互为主从

    http://blog.csdn.net/socho/article/details/51804720 解决Master单点问题,两台mysql互为主备,双向replication.当一master挂 ...

  7. mysql mha 主从自动切换 高可用

    mha(Master High Availability)目前在MySQL多服务器(超过二台),高可用方面是一个相对成熟的解决方案. 一,什么是mha,有什么特性 1. 主服务器的自动监控和故障转移 ...

  8. master&lowbar;pos&lowbar;wait函数与MySQL主从切换

    背景 主从切换是高可用MySQL架构的必要步骤(即使用不发生,也要有备无患).一般设置为双M(M1.M2),假设当前状态为写M1,而M2只读,切换的大致流程如下: 1.  停止应用写M1,将M1设置为 ...

  9. linux下nginx结合keepalived实现主从切换的配置

    linux下nginx结合keepalived实现主从切换的配置   解决方法: 实现一个主nginx宕机,请求转到另一个nginx中. 1.确保两台nginx已启动,假如端口分别是192.168.0 ...

随机推荐

  1. ubuntu 安装compiz后 黑屏无法进入处理

    因为我们显卡的原因而出现不兼容,设置之后会出现菜单栏消失.窗口假死等现象,请保持平静心态,默默重启,如果发现进不去桌面了,可以试试Ctrl+Alt+F1进入字符界面,输入以下命令: dconf res ...

  2. 3 Ways to Preload Images with CSS&comma; JavaScript&comma; or Ajax---reference

    Preloading images is a great way to improve the user experience. When images are preloaded in the br ...

  3. USACO Section 4&period;3 Buy low&comma;Buy lower&lpar;LIS&rpar;

    第一眼看到题目,感觉水水的,不就是最长下降子序列嘛!然后写……就呵呵了..要判重,还要高精度……判重我是在计算中加入各种判断.这道题比看上去麻烦一点,但其实还好吧.. #include<cstd ...

  4. 2017java文件操作(读写操作)

    java的读写操作是学java开发的必经之路,下面就来总结下java的读写操作. 从上图可以开出,java的读写操作(输入输出)可以用"流"这个概念来表示,总体而言,java的读写 ...

  5. jsp九个内置对象、四个域对象及Servlet的三大域对象

    一,什么是内置对象? 在jsp开发中会频繁使用到一些对象,如ServletContext HttpSession PageContext等.如果每次我们在jsp页面中需要使用这些对象都要自己亲自动手创 ...

  6. User Authentication with Angular and ASP&period;NET Core

    User authentication is a fundamental part of any meaningful application. Unfortunately, implementing ...

  7. Aws云服务EMR使用

    Aws云服务EMR使用 创建表结构 创建abc库下的abc_user_i表字段s3://abc-server/abc-emr/shell/ABC_USER_HIVE.q: EXTERNAL 指定为外部 ...

  8. TopCoder SRM502 Div1 1000 动态规划

    原文链接https://www.cnblogs.com/zhouzhendong/p/SRM502-1000.html SRM502 Div1 1000 题意 从 [0,n-1] 中选择 k 个不同的 ...

  9. 使用AndroidStudio上传忽略文件至SVN Server的解决措施

    在同组项目进行共享时,容易把本地的配置文件比如*.iml等文件上传至共享服务器,这样会对队友造成巨大的麻烦,为了解决这个问题,可以使用下面方法解决,下面以上传到服务器的app.iml文件为例. 一.在 ...

  10. Is there anyway to discover which ip addresses are connected to the db&quest;

    From mongo shell run db.currentOp() to show all active connections or db.currentOp(true) to show all ...