mysql双主同步

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

1、数据库同步设置sql

  主机操做系统:centos数据库

  数据库版本:mysql Ver 14.12 Distrib 5.0.22centos

  前提:MYSQL数据库正常启动服务器

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

ServA192.168.0.101  ServB192.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,修改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表示正常;

wKiom1OrmlmQKK8yAAQuCWNtrpg127.jpg

wKioL1Ormi7QpTkyAARbOJUXGi8314.jpg



 

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

相关文章
相关标签/搜索