http://blog.csdn.net/wzy0623/article/details/38757561

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

分类: MySQL2014-08-22 15:39 331人阅读 评论(0) 收藏 举报
一、环境
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.4
MySQL数据库版本:5.6.14
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

[plain] view plaincopy
  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. }

keepalived配置成服务并开机启动

[plain] view plaincopy
  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

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

[plain] view plaincopy
  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

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

[plain] view plaincopy
  1. #!/bin/bash
  2. /etc/init.d/keepalived stop

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

[plain] view plaincopy
  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. }

keepalived配置成服务并开机启动

[plain] view plaincopy
  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

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

[plain] view plaincopy
  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

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

[plain] view plaincopy
  1. #!/bin/bash
  2. /etc/init.d/keepalived stop

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

[plain] view plaincopy
  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
[plain] view plaincopy
  1. chmod 755 /usr/local/bin/lvs_real.sh
  2. 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'"
mysql -u u1 -p12345 -P 6603 -h 192.168.1.4 -e "show variables like 'server_id'"

5. 停掉Slave上的MySQL,看读IP是否去掉了Slave的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'"

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

MySQL主从复制与lvs+keepalived单点写入读负载均衡高可用实验相关推荐

  1. saltstack实现haproxy+keepalived负载均衡+高可用(二)

    一键部署haproxy+keepalived实现负载均衡+高可用 实验环境: !!!!    特别注意: www.westos.org为test1的minion名字 test1: 172.25.1.1 ...

  2. LVS原理详解及部署之五:LVS+keepalived实现负载均衡高可用

    本文我们主要讲解的是LVS通过keepalived来实现负载均衡和高可用,而不是我们第三篇文章介绍的通过手动的方式来进行配置.通过脚本的方式来显示RS节点的健康检查和LVS的故障切换.此文会通过一个实 ...

  3. LVS+Keepalived实现负载均衡高可用

    使用脚本实现LVS负载均衡 环境: 3台主机 DS:192.168.100.1 RS1:192.168.100.11 RS2:192.168.100.12 VIP:192.168.100.100 安装 ...

  4. Lvs+keepAlived实现负载均衡高可用集群(DR实现)

    第1章 LVS 简介 1.1 LVS介绍 LVS是Linux Virtual Server的简写,意为Linux虚拟服务器,是虚拟的服务器集群系统,可在UNIX/LINUX平台下实现负载均衡集群功能. ...

  5. LVS+Keepalived-DR模式负载均衡高可用集群

    LVS+Keepalived DR模式负载均衡+高可用集群架构图 工作原理: Keepalived采用VRRP热备份协议实现Linux服务器的多机热备功能. VRRP,虚拟路由冗余协议,是针对路由器的 ...

  6. Nginx+keepalived负载均衡高可用篇第③版

    Nginx+keepalived负载均衡高可用篇第③版 对付中.小型企业,假如没有资金去购买昂贵的四/七层负载均衡交换机,那么Nginx是不错的七层负载均衡选择,并且可以通过Nginx + Keepa ...

  7. Nginx+KeepAlived实现负载均衡高可用原理

    作者:田超凡 原创博文,严禁复制转载,仿冒必究 nginx负载均衡高可用 什么是负载均衡高可用 nginx作为负载均衡器,所有请求都到了nginx,可见nginx处于非常重点的位置,如果nginx服务 ...

  8. keepalive+nginx实现负载均衡高可用_超详细的LVS+keepalived+nginx实现高性能高可用负载均衡集群教程...

    概述 前面已经介绍了前两部分内容,下面主要介绍在nginx服务器方面的配置和测试整个集群是否可用. 在realserver端配置VIP 1.两台nginx服务器都要执行下面脚本: #vi /etc/r ...

  9. lvs负载均衡—高可用集群(keepalived)

    基本概念: 什么是Keepalived呢,keepalived观其名可知,保持存活,在网络里面就是保持在线了,也就是所谓的高可用或热备,用来防止单点故障(单点故障是指一旦某一点出现故障就会导致整个系统 ...

最新文章

  1. Matlab中的图形句柄(转载)
  2. JZOJ 5441. 【NOIP2017提高A组冲刺11.1】序列
  3. 统计学、数据分析、机器学习常用数据特征汇总
  4. python中的成员运算符_在Python中使用成员运算符的示例
  5. Activity的缓存方法
  6. 小白来学C语言之结构体
  7. python38使用_笨方法学Python 习题38:列表的操作
  8. 大数据之-Hadoop3.x_MapReduce_MapTask工作机制---大数据之hadoop3.x工作笔记0124
  9. React Native屏幕尺寸适配
  10. Python数据结构与算法(1.5)——Python基础之函数与异常
  11. vue开发环境搭建(WebStorm)
  12. 制作本地视频网站 苹果cms 超详细
  13. 事件委托的灵活运用真不会求指教
  14. Java web后端框架
  15. 交通流预测爬坑记(一):交通流数据集,原始数据
  16. 对于苹果电脑mac系统安装了windows双系统恢复成苹果单系统遇到的一些问题
  17. 华为手机备份的通讯录是什么文件_手机怎么备份通讯录?华为手机备份方法大全...
  18. windows版本Mysql免安装版下载及安装步骤
  19. rnss和rdss的应用_北斗RNSS/RDSS多模手持终端设计与实现
  20. 新生儿(早产)婴儿护理行业调研报告 - 市场现状分析与发展前景预测

热门文章

  1. 每天工作3小时就够了
  2. 妈蛋,这玩意还真不得不会!
  3. 4个免费的临时邮箱,保证可用,持续更新
  4. R语言基础知识-学习笔记汇总
  5. rails项目本地运行
  6. 微信公众号文章/菜单添加小程序时路径如何获取?
  7. 项管行知05--可交付成果
  8. PaaS市场迎风口,JEPaaS助你一臂之力
  9. Unity中实现文件加密
  10. usnews美国大学计算机科学排名,最新!2019年USNews美国大学计算机专业排名