前言
面试遇到的问题,当时没答上,现研究整理一下。
基础说明
主库: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)
可以看到 File
和 Position
两个信息,这个在配置从库时需要用到。
创建从库角色
# 分配角色,这个命令会主动创建用户
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
主要就是配置主库的 host
、user
、password
、port
等。
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主从同步配置