设为首页 收藏本站
查看: 687|回复: 0

[经验分享] mysql主主同步+keepalived

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-4-17 08:49:08 | 显示全部楼层 |阅读模式
1.安装数据库,配置主主,然后在keepalived
数据库安装完毕
yum install mysql-server yum install mysql-devel
========================================================
[iyunv@localhost ~]# rpm -qa|grep mysql
mysql-devel-5.1.73-3.el6_5.x86_64
mysql-libs-5.1.73-3.el6_5.x86_64
mysql-5.1.73-3.el6_5.x86_64
mysql-server-5.1.73-3.el6_5.x86_64



mysqladmin -uroot password yaoshao123
主主同步
http://www.iyunv.com/xiaoit/p/3977843.html
http://www.iyunv.com/Linux/2013-05/83784.htm
(1)同步帐号
yao yaoshaoyun
grant replication slave on *.* to 'yao'@'%' identified by 'yaoshao123';
create database zabbix;
(2)vi /etc/my.conf

port = 3306
log_bin=/var/lib/mysql/mysql-binlog
server-id=1
binlog_do_db=zabbix

server-id=2
master-host=192.168.31.154
master-user=yao
master-password=yaoshao123
master-port=3306
master-connect-retry=5
replicate-do-db=zabbix
(3)主主新增添加以下

####server-id=1 原本为主########
#[mysqld]
master-host=192.168.31.154
master-user=yao
master-password=yaoshao123
master-port=3306
master-connect-retry=5
replicate-do-db = zabbix
log-slave-updates
sync_binlog=1
auto_increment_offset=1
auto_increment_increment=2
####server-id=2 原本为备########
#[mysqld]

log_bin=/var/lib/mysql/mysql-binlog
binlog_do_db=zabbix
log-slave-updates
sync_binlog=1
auto_increment_offset=2
auto_increment_increment=2

开始同步,最好锁表,好让从服务器定位同步位置。初次同步完成后,记得解锁。
flush tables with read lock;
unlock tables;
分别查看两台mysql>show slave status是看到
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
说明同步成功


下面是两台的my.conf
A 192.168.31.154
#---------------byyao-------------
port = 3306
log_bin=/var/lib/mysql/mysql-binlog
server-id=1
binlog_do_db=zabbix
#------------zhuzhu--------------
master-host=192.168.31.109
master-user=yao
master-password=yaoshao123
master-port=3306
master-connect-retry=5
replicate-do-db = zabbix
log-slave-updates
sync_binlog=1
auto_increment_offset=1
auto_increment_increment=2
#--------------byyao--------------

B192.168.31.109
#--------------byyao------------
server-id=2
master-host=192.168.31.154
master-user=yao
master-password=yaoshao123
master-port=3306
master-connect-retry=5
replicate-do-db=zabbix
#-------------zhuzhu------------
log_bin=/var/lib/mysql/mysql-binlog
log-slave-updates
sync_binlog=1
auto_increment_offset=2
auto_increment_increment=2
#--------------byyao------------

主主同步效果图


wKiom1Uv4bqwQx_VAATCJIqHDkg193.jpg


往从数据库新建一个表yaoshao,在主数据库查看

wKiom1Uv4bujD2oFAAN5Hr8rzIE469.jpg

wKioL1Uv4xGwiGUKAAN_5_rR7cc111.jpg
----------------------------------------keepalived 配置-----------------------------------
vi /etc/keepalived/keepalived.conf

主AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
vrrp_instance VI_1 {
   state backup       #两台配置此处均是BACKUP
   interface eth0
   virtual_router_id 51
   priority 100       #优先级,另一台改为90
   advert_int 1
   nopreempt          #不抢占,只在优先级高的机器上设置即可,优先级低的机器不设置
   authentication {
       auth_type PASS
       auth_pass 1111
   }
   virtual_ipaddress {
       192.168.31.122
   }
}

virtual_server 192.168.31.122 3306 {
   delay_loop 6
   lb_algo wrr
   lb_kind DR
   persistence_timeout 50        #会话保持时间
   protocol TCP

real_server 192.168.31.154 3306 {
       weight 3
       notify_down /usr/shell/killkeepalived.sh    #检测到mysql服务挂了就执行这个脚本(脚本
要自己写哈)
       TCP_CHECK {
       connect_timeout 10        #连接超时时间
       nb_get_retry 3            #重连次数
       delay_before_retry 3      #重连间隔时间
       connect_port 3306         #健康检查端口
        }
       }
}



备BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB
vrrp_instance VI_1 {
   state backup
   interface eth0
   virtual_router_id 51
   priority 90
   advert_int 1
   authentication {
       auth_type PASS
       auth_pass 1111
   }
   virtual_ipaddress {
       192.168.31.122
   }
}

virtual_server 192.168.31.122 3306 {
   delay_loop 6
   lb_algo wrr
   lb_kind DR
   persistence_timeout 50
   protocol TCP

real_server 192.168.31.109 3306 {
       weight 3
       notify_down /usr/shell/killkeepalived.sh
       TCP_CHECK {
       connect_timeout 10
       nb_get_retry 3
       delay_before_retry 3
       connect_port 3306
           }
       }
}
------------------------脚本--两台都一样-----直接关闭,然后在corntab里尝试对mysqld和keepalived重启--------------
[iyunv@yao ~]# cat /usr/shell/killkeepalived.sh
#/bin/sh
/sbin/service keepalived stop
-----------------或者先判断尝试重启MYSQL不行在关闭keepalived--------
#!/bin/bash
#PATH=/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
A=`ps -C mysqld --no-header|wc -l`
if [ $A -eq 0 ];then
/etc/init.d/mysqld start ##这个地方写你nginx命令的路径
sleep 3
if [`ps -C mysqld --no-header|wc -l` -eq 0 ];then
killall keepalived
fi
fi


------------------------测试效果--------------------
两台机子都开起来,mysql -h 192.168.32.122 -uroot -pyaoshao123
mysql> show databases;
ERROR 2013 (HY000): Lost connection to MySQL server during query
mysql> show databases;
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id:    19
Current database: *** NONE ***

+--------------------+
| Database           |
+--------------------+
| information_schema |
| B                  |
| test               |
| zabbix             |
+--------------------+
4 rows in set (0.04 sec)

===========关闭B这一台================
mysql> show databases;
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id:    143
Current database: *** NONE ***

+--------------------+
| Database           |
+--------------------+
| information_schema |
| A                  |
| test               |
| zabbix             |
+--------------------+

稍微延迟

OK搞定了。。。。。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-57911-1-1.html 上篇帖子: MySQL数据库备份、恢复知识储备 下篇帖子: MySQL中serial关键字的作用 mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表