mysql 同步数据主键_MySQL主主数据同步

本文详细介绍了在CentOS 6.5上配置MySQL 5.6主主数据同步的过程,包括设置服务器ID、配置my.cnf、开启二进制日志、创建同步用户并授权、设置主从复制参数、查看和启动复制状态等步骤,确保了主从数据库的版本、数据一致性和错误处理策略。
摘要由CSDN通过智能技术生成

环境

操作系统版本:CentOS 6.5 64位

MySQL版本:mysql5.6

节点1IP:192.168.0.235 主机名:taojiang1-mysql-01

节点2IP:192.168.0.236 主机名:taojiang2-mysql-02

注意:

1、主从服务器操作系统版本和位数要保持一致

2、Master和Slave数据库的版本要一致

3、Master和Slave数据库中的数据要一致

一、2台服务器关闭SELinux(安全强化,如果你感兴趣)“是linux中支持安全访问控制策略机制的一种特性”

vi /etc/selinux/config

SELINUX=disabled

reboot 重启服务器

二、配置235服务器

1、配置my.cnf

vim /etc/my.cnf

# 服务器的ID,必须唯一,一般设置自己的IP

server_id=235

# 复制过滤:不需要备份的数据库(MySQL库一般不同步)

binlog-ignore-db=mysql

# 开启二进制日志功能,名字可以随便取,最好有含义(比如项目名)

log-bin=edu-mysql-bin

# 为每个 session 分配的内存,在事务过程中用来存储二进制日志的缓存

binlog_cache_size=1M

# 主从复制的格式(mixed,statement,row,默认格式是 statement)

binlog_format=mixed

# 二进制日志自动删除/过期的天数。默认值为 0,表示不自动删除。

expire_logs_days=7

## 跳过主从复制中遇到的所有错误或指定类型的错误,避免 slave 端复制中断。

## 如:1062 错误是指一些主键重复,1032 错误是因为主从数据库数据不一致,all所有错误

slave_skip_errors=all

# 作为从服务器时的中继日志

relay_log=taojiang1-mysql-relay-bin

# log_slave_updates 表示 slave 将复制事件写进自己的二进制日志

log_slave_updates=1

# 主键自增规则,避免主从同步ID重复的问题

auto_increment_increment=2 # 自增因子(每次加2)

auto_increment_offset=1 # 自增偏移(从1开始),单数

2 、192.168.0.235配置

# 先重启一下服务

service mysql restart

# 登录到mysql

shell> mysql -uroot -p

# 创建数据库同步用户,并授予相应的权限

mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.0.236' identified by 'repl123';

# 刷新授权表信息

mysql> flush privileges;

# 查看binlog文件的position(偏移)和File(日志文件)的值,从机上需要用到

mysql> show master status;

+----------------------+----------+--------------+------------------+-------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |

+----------------------+----------+--------------+------------------+-------------------+

| taojiag1-mysql-bin.000001 | 001 | | mysql | |

+----------------------+----------+--------------+------------------+-------------------+

3 、192.168.0.236配置

配置之前需要在236上能通过添加的用户repl能访问235上的数据库

mysql -h 192.168.0.235 -u repl -p repl123

change master to master_host='192.168.0.235',

master_user='repl',

master_password='repl123',

master_port=3306,

master_log_file='taojiang1-mysql-bin.000001',

master_log_pos=0,

master_connect_retry=30;

如果master_log_pos=0;系统会自动匹配的.

4、查看192.168.0.235节点状态

mysql> show slave status\G;

Slave_IO_Running: No

Slave_SQL_Running: No

表示为启用

三、配置192.168.0.236

1、vim /etc/my.cnf

server_id=236

binlog-ignore-db=mysql

log-bin=edu-mysql-bin

binlog_cache_size=1M

binlog_format=mixed

expire_logs_days=0

slave_skip_errors=all

relay_log=edu-mysql-relay-bin

log_slave_updates=1

#ID自增从2开始,双数

auto_increment_increment=2

auto_increment_offset=2

————————————————

配置好保存重启数据库

service mysql restart

2、创建数据库同步用户,并授予相应的权限

mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.0.235' identified by 'repl123';

# 刷新授权表信息

mysql> flush privileges;

# 查看binlog文件的position(偏移)和File(日志文件)的值,从机上需要用到

mysql> show master status;

+----------------------+----------+--------------+------------------+-------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |

+----------------------+----------+--------------+------------------+-------------------+

| taojiang2-mysql-bin.000001 | 439 | | mysql | |

+----------------------+----------+--------------+------------------+-------------------+

3 、192.168.0.235配置

配置之前需要在235上能通过添加的用户repl能访问236上的数据库

mysql -h 192.168.0.236 -u repl -p repl123

change master to master_host='192.168.0.236',

master_user='repl',

master_password='repl123',

master_port=3306,

master_log_file='taojiang2-mysql-bin.000001',

master_log_pos=0,

master_connect_retry=30;

Query OK, 0 rows affected, 2 warnings (0.00 sec)

四 、全部配置好后启动slave;

start slave 启动;

stop slave 停止;

reset slave 重置;

1、验证;

show slave status\G;

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

全部YES即配置成功

2、测试

在两台服务器上新建删除数据库是否成功

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值