在实际项目中,两台分布于异地的主机上安装有MYSQL数据库,两台服务器互为主备,客户要求当其中一台机器出现故障时,另一台可以接管服务器上的应用,这就须要两台数据库的数据要实时保持一致,在这里使用MYSQL的同步功能实现双机的同步复制。mysql
1、数据库同步设置sql
主机操做系统:centos数据库
数据库版本:mysql Ver 14.12 Distrib 5.0.22centos
前提:MYSQL数据库正常启动服务器
假设两台主机地址分别为:网络
ServA:192.168.0.101 ServB:192.168.0.203ide
Iptables 开发3306端口测试
1.1 配置同步帐号spa
在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的my.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,修改ServB的my.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表示正常;
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数据库后测试,该问题解决。