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

fa054142e9b76b19b5efdf5aa12c8c21.png

46bc47ecb5360691115e6f1fba8f7f7a.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值