MySQL主从同步配置

前言

面试遇到的问题,当时没答上,现研究整理一下。

基础说明

主库:192.168.33.18
从库:192.168.33.15

主要流程

  • 主库将数据库所有的增删改操作记录在 Binlog
  • 从库复制主库的 Binlog 文件到本地
  • 从库读取日志中的事件,并执行

设置主库

开启Binlog

修改 MySQL 的配置文件 my.cnf

sudo vim /etc/mysql/my.cnf

添加主库的配置:

[mysqld]
# 指定 Binlog 的位置
log-bin=/var/log/mysql/mysql-bin.log

# 指定主库的 server id
server-id=1

# 可以指定需要记录的库
# 需要记录多个库,只需要重复配置 binlog-do-db
binlog-do-db=test_db

# 也可以指定不需要记录的库
binlog-ignore-db=mysql

配置文件修改过后,需要重启 MySQL 才可以生效:

sudo service mysql restart

这时,登录 MySQL,查看主库的 Position 值:

show master status;

+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |      110 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

可以看到 FilePosition 两个信息,这个在配置从库时需要用到。

创建从库角色

# 分配角色,这个命令会主动创建用户
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.33.15' IDENTIFIED BY '123456';

# 刷新权限
FLUSH PRIVILEGES;

数据导出

首先:停机!!!虽然网上有不少加读锁的,可是加了读锁同样会影响业务,还是停机来的更加彻底。

接下来就是将数据导出了,可以直接拷贝所有数据库文件,也可以使用 mysqldump

命令如下[1]

# 针对事务性引擎
mysqldump -uroot -ptiger --all-database -e --single-transaction --flush-logs --max_allowed_packet=1048576 --net_buffer_length=16384 > /data/all_db.sql

# 针对 MyISAM 引擎,或多引擎混合的数据库
mysqldump -uroot --all-database -e -l --flush-logs --max_allowed_packet=1048576 --net_buffer_length=16384 > /data/all_db.sql

从库配置

这里有一个注意点,就是要确保能够连通主库,所以建议先用命令行登录主库的 MySQL

修改配置文件

sudo vim /etc/mysql/my.cnf

添加从库配置:

[mysqld]
# 配置 server id
# 这里的 server-id 需要和从库的不一样,不然同步会报错
server-id=2

配置完成后,需要重启 MySQL

sudo service mysql restart

导入数据

为保持主从数据库在一个起点,需要导入主库备份好的数据。

数据文件 all_db.sql 来自上述导出。

mysql -h 127.0.0.1 -u root -p < all_db.sql

指定master

主要就是配置主库的 hostuserpasswordport 等。

CHANGE MASTER TO
MASTER_HOST='192.168.33.18',
MASTER_USER='slave',
MASTER_PASSWORD='123456',
MASTER_PORT=3306,
MASTER_LOG_FILE='mysql-bin.00001',
MASTER_LOG_POS='110';

开启从库

start slave;

至此,配置成功。

测试

主从库

创建一个名为 test_db 的数据库。

主库创建数据库

创建一张表。

主库创建表

删除库。

主库删除数据库

检测成功。

踩坑

配置期间遇到过几个问题,现记录一下。

1 Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work

首先检查主库和从库配置的 server-id 是否一致,若一致,则改为不一致,然后重启数据库。

若不一致,再检查 /var/lib/mysql/auto.cnf[2] 里的 server-uuid 是否一致,若一致,则删除其中一个,然后重启数据库。

若再不行,还是 Google 吧。

2 Got fatal error 1236 from master when reading data from binary log: 'Binary log is not open'

是因为主库的配置文件没有生效,检查主库配置,然后重启数据库。再在从库 start slave; 就好。

3 error connecting to master '[email protected]:3306' - retry-time: 60 retries: 1

链接主库错误,需要检查主库分配的角色和权限是否正确。

参考文献

[1] mysql主从复制及问题解决

[2] 详述查看 MySQL 数据文件存储位置的方法

-- EOF --
本文转载自IMJCW
原文链接:MySQL主从同步配置

你可能感兴趣的:(MySQL主从同步配置)