2019独角兽企业重金招聘Python工程师标准>>>

一、环境
Master(主机A):192.168.1.1
Slave(主机B) :192.168.1.2  
W-VIP(写入)  :192.168.1.3 
R-VIP(读取)  :192.168.1.4 
Client(测试) :192.168.1.100

操作系统版本:CentOS release 6.5
MySQL数据库版本:5.5.13
keepalived版本:1.2.7
LVS版本:1.26

所有环境均为虚拟机

二、设计思路

1. 服务器A和B,通过mysql的slave进程同步数据。
2. 通过keepalived启用两个虚IP:W-VIP/R-VIP,一个负责写入,一个负责读取,实现读写分离。
3. A和B都存在时,W-VIP下将请求转发至主机A,R-VIP将请求转发给A和B,实现负载均衡。
4. 当主机A异常时,B接管服务,W-VIP/R-VIP此时漂到了主机B上,此时这两个虚IP下都是主机B,实现高可用
5. 当主机B异常时,R-VIP会将B踢出,其他不变

三、架构图

四、软件安装
主从两个主机都要装以下软件:
1. MySQL的安装(略)
2. keepalived安装
yum install keepalived
2. LVS安装
yum install ipvsadm

五、配置
1. 配置MySQL的主从复制(略)
2. 配置keepalived
Master上的配置
vi /etc/keepalived/keepalived.conf

  1. ! Configuration File for keepalived
  2. global_defs {
  3. router_id MySQL-ha
  4. }
  5. vrrp_instance VI_1 {
  6. state BACKUP
  7. interface eth1
  8. virtual_router_id 90
  9. priority 100
  10. advert_int 1
  11. notify_master "/usr/local/mysql/bin/remove_slave.sh"
  12. nopreempt
  13. authentication {
  14. auth_type PASS
  15. auth_pass 1111
  16. }
  17. virtual_ipaddress {
  18. 192.168.1.3 label eth1:1
  19. 192.168.1.4 label eth1:2
  20. }
  21. }
  22. virtual_server 192.168.1.3 6603 {
  23. delay_loop 2
  24. lb_algo wrr
  25. lb_kind DR
  26. persistence_timeout 60
  27. protocol TCP
  28. real_server 192.168.1.1 6603 {
  29. weight 3
  30. notify_down /usr/local/mysql/bin/mysql.sh
  31. TCP_CHECK {
  32. connect_timeout 10
  33. nb_get_retry 3
  34. delay_before_retry 3
  35. connect_port 6603
  36. }
  37. }
  38. }
  39. virtual_server 192.168.1.4 6603 {
  40. delay_loop 2
  41. lb_algo wrr
  42. lb_kind DR
  43. persistence_timeout 60
  44. protocol TCP
  45. real_server 192.168.1.1 6603 {
  46. weight 1
  47. notify_down /usr/local/mysql/bin/mysql.sh
  48. TCP_CHECK {
  49. connect_timeout 10
  50. nb_get_retry 3
  51. delay_before_retry 3
  52. connect_port 6603
  53. }
  54. }
  55. real_server 192.168.1.2 6603 {
  56. weight 3
  57. TCP_CHECK {
  58. connect_timeout 10
  59. nb_get_retry 3
  60. delay_before_retry 3
  61. connect_port 6603
  62. }
  63. }
  64. }

! Configuration File for keepalived global_defs { router_id MySQL-ha } vrrp_instance VI_1 { state BACKUP interface eth1 virtual_router_id 90 priority 100 advert_int 1 notify_master "/usr/local/mysql/bin/remove_slave.sh" nopreempt authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.1.3 label eth1:1 192.168.1.4 label eth1:2 } } virtual_server 192.168.1.3 6603 { delay_loop 2 lb_algo wrr lb_kind DR persistence_timeout 60 protocol TCP real_server 192.168.1.1 6603 { weight 3 notify_down /usr/local/mysql/bin/mysql.sh TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 connect_port 6603 } } } virtual_server 192.168.1.4 6603 { delay_loop 2 lb_algo wrr lb_kind DR persistence_timeout 60 protocol TCP real_server 192.168.1.1 6603 { weight 1 notify_down /usr/local/mysql/bin/mysql.sh TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 connect_port 6603 } } real_server 192.168.1.2 6603 { weight 3 TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 connect_port 6603 } } }

keepalived配置成服务并开机启动

  1. cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
  2. cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
  3. cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
  4. chkconfig --add keepalived
  5. chkconfig --level 345 keepalived on

cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/ cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/ cp /usr/local/keepalived/sbin/keepalived /usr/sbin/ chkconfig --add keepalived chkconfig --level 345 keepalived on

vi /usr/local/mysql/bin/remove_slave.sh

  1. #!/bin/bash
  2. user=u1
  3. password=12345
  4. log=/usr/local/mysql/log/remove_slave.log
  5. echo "`date`" >> $log
  6. /usr/local/mysql/bin/mysql -u$user -p$password -e "set global read_only=OFF;reset master;stop slave;change master to master_host='localhost';" >> $log
  7. /bin/sed -i 's#read-only#\#read-only#' /etc/my.cnf

#!/bin/bash user=u1 password=12345 log=/usr/local/mysql/log/remove_slave.log echo "`date`" >> $log /usr/local/mysql/bin/mysql -u$user -p$password -e "set global read_only=OFF;reset master;stop slave;change master to master_host='localhost';" >> $log /bin/sed -i 's#read-only#\#read-only#' /etc/my.cnf

vi /usr/local/mysql/bin/mysql.sh

  1. #!/bin/bash
  2. /etc/init.d/keepalived stop

#!/bin/bash /etc/init.d/keepalived stop

Slave上的配置
vi /etc/keepalived/keepalived.conf

[plain]view plaincopyprint?

  1. ! Configuration File for keepalived
  2. global_defs {
  3. router_id MySQL-ha
  4. }
  5. vrrp_instance VI_1 {
  6. state BACKUP
  7. interface eth1
  8. virtual_router_id 90
  9. priority 99
  10. advert_int 1
  11. notify_master "/usr/local/mysql/bin/remove_slave.sh"
  12. authentication {
  13. auth_type PASS
  14. auth_pass 1111
  15. }
  16. virtual_ipaddress {
  17. 192.168.1.3 label eth1:1
  18. 192.168.1.4 label eth1:2
  19. }
  20. }
  21. virtual_server 192.168.1.3 6603 {
  22. delay_loop 2
  23. lb_algo wrr
  24. lb_kind DR
  25. persistence_timeout 60
  26. protocol TCP
  27. real_server 192.168.1.2 6603 {
  28. weight 3
  29. notify_down /usr/local/mysql/bin/mysql.sh
  30. TCP_CHECK {
  31. connect_timeout 10
  32. nb_get_retry 3
  33. delay_before_retry 3
  34. connect_port 6603
  35. }
  36. }
  37. }
  38. virtual_server 192.168.1.4 6603 {
  39. delay_loop 2
  40. lb_algo wrr
  41. lb_kind DR
  42. persistence_timeout 60
  43. protocol TCP
  44. real_server 192.168.1.2 6603 {
  45. weight 3
  46. notify_down /usr/local/mysql/bin/mysql.sh
  47. TCP_CHECK {
  48. connect_timeout 10
  49. nb_get_retry 3
  50. delay_before_retry 3
  51. connect_port 6603
  52. }
  53. }
  54. }

! Configuration File for keepalived global_defs { router_id MySQL-ha } vrrp_instance VI_1 { state BACKUP interface eth1 virtual_router_id 90 priority 99 advert_int 1 notify_master "/usr/local/mysql/bin/remove_slave.sh" authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.1.3 label eth1:1 192.168.1.4 label eth1:2 } } virtual_server 192.168.1.3 6603 { delay_loop 2 lb_algo wrr lb_kind DR persistence_timeout 60 protocol TCP real_server 192.168.1.2 6603 { weight 3 notify_down /usr/local/mysql/bin/mysql.sh TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 connect_port 6603 } } } virtual_server 192.168.1.4 6603 { delay_loop 2 lb_algo wrr lb_kind DR persistence_timeout 60 protocol TCP real_server 192.168.1.2 6603 { weight 3 notify_down /usr/local/mysql/bin/mysql.sh TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 connect_port 6603 } } }
keepalived配置成服务并开机启动

[plain]view plaincopyprint?

  1. cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
  2. cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
  3. cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
  4. chkconfig --add keepalived
  5. chkconfig --level 345 keepalived on

cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/ cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/ cp /usr/local/keepalived/sbin/keepalived /usr/sbin/ chkconfig --add keepalived chkconfig --level 345 keepalived on
vi /usr/local/mysql/bin/remove_slave.sh

[plain]view plaincopyprint?

  1. #!/bin/bash
  2. user=u1
  3. password=12345
  4. log=/usr/local/mysql/log/remove_slave.log
  5. echo "`date`" >> $log
  6. /usr/local/mysql/bin/mysql -u$user -p$password -e "set global read_only=OFF;reset master;stop slave;change master to master_host='localhost';" >> $log
  7. /bin/sed -i 's#read-only#\#read-only#' /etc/my.cnf

#!/bin/bash user=u1 password=12345 log=/usr/local/mysql/log/remove_slave.log echo "`date`" >> $log /usr/local/mysql/bin/mysql -u$user -p$password -e "set global read_only=OFF;reset master;stop slave;change master to master_host='localhost';" >> $log /bin/sed -i 's#read-only#\#read-only#' /etc/my.cnf

vi /usr/local/mysql/bin/mysql.sh

[plain]view plaincopyprint?

  1. #!/bin/bash
  2. /etc/init.d/keepalived stop

#!/bin/bash /etc/init.d/keepalived stop

3. 配置LVS
Master与Slave上的配置相同:
vi /usr/local/bin/lvs_real.sh

[plain]view plaincopyprint?

  1. #!/bin/bash
  2. # description: Config realserver lo and apply noarp
  3. SNS_VIP=192.168.1.3
  4. SNS_VIP2=192.168.1.4
  5. source /etc/rc.d/init.d/functions
  6. case "$1" in
  7. start)
  8. ifconfig lo:0 $SNS_VIP netmask 255.255.255.255 broadcast $SNS_VIP
  9. ifconfig lo:1 $SNS_VIP2 netmask 255.255.255.255 broadcast $SNS_VIP2
  10. /sbin/route add -host $SNS_VIP dev lo:0
  11. /sbin/route add -host $SNS_VIP2 dev lo:1
  12. echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
  13. echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
  14. echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
  15. echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
  16. sysctl -p >/dev/null 2>&1
  17. echo "RealServer Start OK"
  18. ;;
  19. stop)
  20. ifconfig lo:0 down
  21. ifconfig lo:1 down
  22. route del $SNS_VIP >/dev/null 2>&1
  23. route del $SNS_VIP2 >/dev/null 2>&1
  24. echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
  25. echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
  26. echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
  27. echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
  28. echo "RealServer Stoped"
  29. ;;
  30. *)
  31. echo "Usage: $0 {start|stop}"
  32. exit 1
  33. esac
  34. exit 0

#!/bin/bash # description: Config realserver lo and apply noarp SNS_VIP=192.168.1.3 SNS_VIP2=192.168.1.4 source /etc/rc.d/init.d/functions case "$1" in start) ifconfig lo:0 $SNS_VIP netmask 255.255.255.255 broadcast $SNS_VIP ifconfig lo:1 $SNS_VIP2 netmask 255.255.255.255 broadcast $SNS_VIP2 /sbin/route add -host $SNS_VIP dev lo:0 /sbin/route add -host $SNS_VIP2 dev lo:1 echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce sysctl -p >/dev/null 2>&1 echo "RealServer Start OK" ;; stop) ifconfig lo:0 down ifconfig lo:1 down route del $SNS_VIP >/dev/null 2>&1 route del $SNS_VIP2 >/dev/null 2>&1 echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce echo "RealServer Stoped" ;; *) echo "Usage: $0 {start|stop}" exit 1 esac exit 0

[plain]view plaincopyprint?

  1. chmod 755 /usr/local/bin/lvs_real.sh
  2. echo "/usr/local/bin/lvs_real.sh start" >> /etc/rc.local

chmod 755 /usr/local/bin/lvs_real.sh echo "/usr/local/bin/lvs_real.sh start" >> /etc/rc.local

五、Master和Slave的启动
1. 启动Master上的MySQL
service mysql start
2. 启动Slave上的MySQL
service mysql start
3. 启动Master上的realserver脚本
/usr/local/bin/lvs_real.sh start
4. 启动Slave上的realserver脚本
/usr/local/bin/lvs_real.sh start
5. 启动Master上的keepalived
service keepalived start
6. 启动Slave上的keepalived
service keepalived start

六、测试
1. 查看lvs能否进行负载均衡转发
在Master和Slave上分别执行:
ipvsadm -ln

2. 在Client上验证连通性:
ping 192.168.1.3
ping 192.168.1.4
mysql -u u1 -p12345 -P 6603 -h 192.168.1.3 -e "show variables like 'server_id'"
mysql -u u1 -p12345 -P 6603 -h 192.168.1.4 -e "show variables like 'server_id'"

3. 停掉Master上的MySQL,看写IP否自动切换到Slave,看读IP是否去掉了Master的MySQL
在Master和Slave上分别执行:
ipvsadm -ln
在Client上执行:
mysql -u u1 -p12345 -P 6603 -h 192.168.1.3 -e "show variables like 'server_id'"
mysql -u u1 -p12345 -P 6603 -h 192.168.1.4 -e "show variables like 'server_id'"

4. 停掉Master上的keepalived,看读写VIP是否会迁移到Slave上。
在Master和Slave上分别执行:
ipvsadm -ln
在Client上执行:
mysql -u u1 -p12345 -P 6603 -h 192.168.1.3 -e "show variables like 'server_id'"

在Master和Slave上分别执行:
ipvsadm -ln
在Client上执行:
mysql -u u1 -p12345 -P 6603 -h 192.168.1.3 -e "show variables like 'server_id'"
mysql -u u1 -p12345 -P 6603 -h 192.168.1.4 -e "show variables like 'server_id'"

6. 重启Master的系统,看看切换过程是否正常

七、参考
http://wenku.baidu.com/link?url=17K0UDApzfK18A8F5Of9wl0lmGx6AD_0PQ8GyVqmCsBMSz16xjt2JI88lPAeID2qECs7piUxkzQLyatTtDuEJxwZEy6joIBfBmT3vgTfdUS
http://blog.chinaunix.net/uid-23500957-id-3781918.html
http://blog.chinaunix.net/uid-23500957-id-3781919.html
http://blog.chinaunix.net/uid-20639775-id-3337471.html

转载于:https://my.oschina.net/u/2350399/blog/715737

mysql主从复制 lvs+ keepalived相关推荐

  1. MySQL主从复制与lvs+keepalived单点写入读负载均衡高可用实验

    http://blog.csdn.net/wzy0623/article/details/38757561 MySQL主从复制与lvs+keepalived单点写入读负载均衡高可用实验 分类: MyS ...

  2. mysql dba系统学习(18)mysql主从复制的实现 mysql dba系统学习(19)配置mysql+lvs+keeplived实现Mysql读操作的负载均衡

    mysql主从复制的实现 1.MySQL复制的实现原理 MySQL支持单向.双向复制.异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入一个二进制日志文 ...

  3. mysql+keepalived必须要lvs吗_MySQL 双主热备 + LVS + Keepalived 高可用操作记录

    MySQL复制能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.然而MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现负 ...

  4. mysql+keepalived必须要lvs吗_Mysql双主热备+LVS+Keepalived高可用操作记录

    MySQL复制能够保证数据的冗余的同时可以做读写分离来分担系统压力,如果是主主复制还可以很好的避免主节点的单点故障.然而MySQL主主复制存在一些问题无法满足我们的实际需要:未提供统一访问入口来实现负 ...

  5. linuxweb集群mysql_企业web高可用集群实战之lvs+keepalived+mysql

    前端用两台server做lvs+keepalived负载调度器,中间用apache+php作为web应用服务器,后端用两台做mysql高可用,用nfs.mfs或作为web文件共享服务器 系统环境: L ...

  6. mysql从 lvs_linux keepalived+LVS 实现mysql 从库负载均衡

    前情提要: 参考链接: http://www.osyunwei.com/archives/7464.html ps:以上为本次操作的主要参考资料,非常感谢此文作者的贡献,我的随笔的主要目的是 说明在使 ...

  7. MySQL集群架构-DRBD+headbeat +lvs+keepalived

    DRBD+headbeat +lvs+keepalived 转载于:https://www.cnblogs.com/elontian/p/8820333.html

  8. Mysql主从复制详解和实战

    一.主从复制原理 1.1 基本介绍 MySQL 内建的复制功能是构建大型,高性能应用程序的基础.将 MySQL 的 数亿分布到到多个系统上去,这种分步的机制,是通过将 MySQL 的某一台主机的数据复 ...

  9. centos6.9负载均衡方案完整配置(lvs+keepalived+pxc+nfs+业务系统)

    前期准备: NFS服务器:计算机名nfsserver,IP地址192.168.1.103,用于存放业务系统的数据. node1:计算机名PXC01,IP地址192.168.1.105,安装pxc系统和 ...

最新文章

  1. Python做web前后端交互
  2. 047_BOM_DOM
  3. UVAPOJ离散概率与数学期望入门练习[4]
  4. 推荐两个在线格式化JavaScript代码的网站
  5. markdown 本地链接_记录笔记、markdown工具推荐
  6. 微课|《Python编程基础与案例集锦(中学版)》第2章(2)
  7. C++_类和对象_封装_访问权限_C++中struct和class的区别---C++语言工作笔记037
  8. dubbo这样的RPC接口与HTTP接口相比,有什么优势,以及HTTP请求中的三次握手
  9. win10易升_win10性能模式是什么?怎么开启?
  10. Java 机器学习库Smile实战(一)SVM
  11. 思科路由器基本配置命令
  12. mysql查询IP地址
  13. ps教程300集,让你入门就精通(内附资源)
  14. 目前巨型计算机应用最主要的领域是,A.10%-15%.
  15. 【论文笔记】虚拟领导者控制编队机动
  16. 程序员职业发展路线图(完整版+珍藏版)
  17. 一对一直播源码、一对一聊天app源码前端后台功能说明
  18. 变量four赋值数字python_第2节:初识python
  19. 建网站之前要先做好SEO布局工作
  20. 达菲抗流感原理及作用

热门文章

  1. call和ret(f)指令
  2. hadoop put命令的格式_HDFS常用命令
  3. 80. 删除排序数组中的重复项 II golang
  4. visual studio 2015 配置好qt5后, 第一次运行出现 无法打开源文件“QtWidgets/QApplication”和无法运行rc.exe的解决方案
  5. [剑指Offer]替换空格
  6. 数据可视化【三】基本概念
  7. 混合字符串字符数统计
  8. 1079. Total Sales of Supply Chain (25)
  9. read和write函数的使用
  10. 美团点评APP在移动网络性能优化的实践,赶快收藏备战金九银十!