mysql双主同步时间_mysql双主同步
mysql双主同步时间_mysql双主同步
在实际项⽬中,两台分布于异地的主机上安装有MYSQL数据库,两台服务器互为主备,客户要求当其中⼀台机器出现故障时,另外⼀台能够接管服务器上的应⽤,这就需要两台数据库的数据要实时保持⼀致,在这⾥使⽤MYSQL的同步功能实现双机的同步复制。
1、数据库同步设置
主机操作系统:centos
数据库版本:mysql Ver 14.12 Distrib 5.0.22
前提:MYSQL数据库正常启动
假设两台主机地址分别为:
ServA:192.168.0.101ServB:192.168.0.203
Iptables 开发3306端⼝
基金考试报名
1.1 配置同步账号
在ServA上授权⼀个ServB可以登录的帐号:
GRANT all privileges ON *.* TO root@‘192.168.0.203‘ IDENTIFIED BY ‘123456‘;
语文复习计划在ServB上授权⼀个ServA可以登录的帐号:
GRANT all privileges ON *.* TO root@‘192.168.0.101‘ IDENTIFIED BY ‘123456‘;
1.2 配置数据库参数
1、 以root⽤户登录ServA,修改ServA的myf⽂件
小满节气的含义是什么vi /etc/myf
在[mysqld]的配置项中增加如下配置:
中考加油
魾default-character-set=utf8
log-bin=mysql-bin
relay-log=relay-bin
relay-log-index=relay-bin-index
server-id=1
master-host=192.168.0.203
master-user=root
master-password=123456
master-port=3306
master-connect-retry=30
binlog-do-db=abc
replicate-do-db=abc
replicate-ignore-table=umsdb.boco_tb_menu
replicate-ignore-table=umsdb.boco_tb_connect_log
replicate-ignore-table=umsdb.boco_tb_data_stat
replicate-ignore-table=umsdb.boco_tb_log_record replicate-ignore-table=umsdb.boco_tb_workorder_record 2、以root⽤户登录ServB,修改ServB的myf⽂件
vi /etc/myf
在[mysqld]的配置项中增加如下配置:
default-character-set=utf8
log-bin=mysql-bin
relay-log=relay-bin
relay-log-index=relay-bin-index
server-id=2
master-host=192.168.0.101
master-user=root
master-password=123456
master-port=3306
master-connect-retry=30
斗罗大陆155集柳二龙binlog-do-db=abc
replicate-do-db=abc
replicate-ignore-table=umsdb.boco_tb_menu
replicate-ignore-table=umsdb.boco_tb_connect_log replicate-ignore-table=umsdb.boco_tb_data_stat
replicate-ignore-table=umsdb.boco_tb_log_record replicate-ignore-table=umsdb.boco_tb_workorder_record 1.3 ⼿⼯执⾏数据库同步
假设以ServA为主服务器,在ServB上重启mysql:
service mysqld restart
在ServB上⽤root⽤户登录mysql,执⾏:
Mysql> stop slave;
Mysql> load data from master;
Mysql> start slave;
在ServA上重启mysql:
service mysqld restart
1.4查看数据库同步状态
在mysql命令提⽰符下执⾏:
Mysql> show slave status\G
将显⽰同步进程的状态,如下所⽰,如果都为yes表⽰正常;
3、 数据库同步测试
配置完数据库后进⾏测试,⾸先在⽹络正常情况下测试,在ServA上进⾏数据库操作,和在ServB上进⾏数据库操作,数据都能够同步过去。
拔掉ServB主机上的⽹线,然后在ServA上做⼀些数据库操作,之后再恢复ServB的⽹络环境,但是在ServB上却看不到同步的数据,通过命令show slave status\G查看发现Slave_IO_Running的状态是No,这种状态持续很长⼀段时间,数据才能同步到ServB上去。这是什么问题呢?同步延迟不会这么⼤吧。后来通过⽹上查相关资料,到⼀个同步延迟相关的参数:
--slave-net-timeout=seconds
参数含义:当slave从主数据库读取log数据失败后,等待多久重新建⽴连接并获取数据。
于是在配置⽂件中增加该参数,设置为60秒
slave-net-timeout=60
重启MYSQL数据库后测试,该问题解决。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。