mysql主从同步
- 实现数据自动同步的服务结构
- 主服务器:接受客户端访问连接
- 从服务器:自动同步主服务器数据到本机
原理示意:
master:binlog日志
slave:包括两个线程
- Slave_IO:复制master主机binlog日志文件里的SQL命令到本机的relay-log文件里
- Slave_SQL:执行本机relay-log文件里的SQL语句,实现与master数据一致
配置主从同步(一主一从)
配置master服务器
- 启用binlog日志 binlog启用方法
- 查看日志信息
- 用户授权
mysql> grant replication slave on *.* to USER@'%' identified by 'PASSWORD';
配置slave服务器
- 修改主配置文件
- 确保与主服务器数据一致
- 指定主服务器信息
- 启动服务查看状态
修改配置文件
[root@slave ~]vim /etc/my.cnf
[mysqld]
server_id=52 #不允许与主服务器相同
...
同步数据
- 在主服务器上备份数据,将备份数据拷贝给从服务器
- 在从服务器使用备份文件恢复数据
- 在从服务器查看备份文件记录的binlog日志信息
[root@master ~] mysqldump -uroot -pPASSWORD --master-data 数据库名 > /allbak.sql #--master-data记录当前备份数据对应的日志信息
[root@master ~] scp /allbak.sql root@'从服务器':
[root@slave ~] mysql -uroot -pPASSWORD 数据库名 < /allbak.sql
[root@slave ~] grep binlog日志文件名 /allbak.sql
CHANGE MASTER TO MASTER_LOG_FILE='master51.000001', MASTER_LOG_POS=441; #指定主服务器需要的信息:binlog日志名和偏移量
指定主服务器信息
[root@slave ~] mysql -uroot -pPASSWORD
mysql> change master to
-> master_host="IP", #主服务器ip地址
-> master_user="USER", #主服务器授权用户
-> master_password="PASSWORD", #授权用户密码
-> master_log_file="MASTER_LOG_FILE", #主服务器正在使用的binlog日志
-> master_log_pos=MASTER_LOG_POS; #日志偏移量
#master信息会自动保存到/var/lib/mysql/master.info文件
#若更改主服务器信息时,应先执行stop slave; , 修改后再执行start slave;
mysql> start slave; #启动slave进程
查看状态(确认IO和SQL线程处于Yes状态)
mysql> show slave status\G; #这里只写了部分
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.4.51 #主服务器地址
Master_User: repluser #用户名
Master_Port: 3306 #主服务器端口
Connect_Retry: 60
Master_Log_File: master51.000001
Read_Master_Log_Pos: 441
Relay_Log_File: mysql52-relay-bin.000002 #中继日志relay
Relay_Log_Pos: 319
Relay_Master_Log_File: master51.000001
Slave_IO_Running: Yes #I/O线程,Yes为运行中
Slave_SQL_Running: Yes #SQL线程
Last_IO_Errno: 0
Last_IO_Error: #IO报错信息
Last_SQL_Errno: 0
Last_SQL_Error: #SQL报错信息
Replicate_Ignore_Server_Ids:
Master_Server_Id: 51
Master_UUID: a6d5ce61-3136-11ea-bc0e-52540042b7a1 #UUID保存在数据库目录下的auto.cnf中
Master_Info_File: /var/lib/mysql/master.info #保存master信息的文件
SQL_Delay: 0
SQL_Remaining_Delay: NULL
Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
1 row in set (0.00 sec)
相关文件(数据库目录下)
文件名 | 说明 |
---|---|
master.info | 主库信息 |
relay-log.info | 中继日志信息 |
主机名-relay-bin.xxxxxx | 中继日志(默认只保留2个文件,当第三个文件创建时,会删除第一个文件) |
主机名-relay-bin.index | 索引文件 |
删除以上文件,重启服务,可以把数据库还原为独立数据库服务器
测试
客户端连接主服务器操作数据,连接从服务器也可以看到相同数据