在实际项目中,两台分布于异地的主机上安装有MYSQL数据库,两台服务器互为主备,客户要求当其中一台机器出现故障时,另外一台能够接管服务器上的应用,这就需要两台数据库的数据要实时保持一致,在这里使用MYSQL的同步功能实现双机的同步复制。

1、数据库同步设置

  主机操作系统:centos

  数据库版本:mysql Ver 14.12 Distrib 5.0.22

  前提:MYSQL数据库正常启动

  假设两台主机地址分别为:

ServA192.168.0.101  ServB192.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,修改ServAmy.cnf文件

  vi /etc/my.cnf

  在[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,修改ServBmy.cnf文件

  vi /etc/my.cnf

[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

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表示正常;

mysql双主同步_数据库

mysql双主同步_同步_02



 

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数据库后测试,该问题解决。