mysql reset master 有风险吗

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql reset master 有风险吗相关的知识,希望对你有一定的参考价值。

PURGE MASTER | BINARY LOGS TO 'log_name' PURGE MASTER | BINARY LOGS BEFORE 'date' 用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件中的清单中被删除,这样被给定的日志成为第一个... 参考技术A 重置主从服务器,对于解决主库与从库不同步问题,也许是最安全有效的做法了;
这种做法本身风险已经最小,但操作不当的话,也是会出现问题的;
比方说:
1.master 没有加锁,导致备份的同时,数据库存在更新动作;
2.重置 master 时 binlog 被删除,slave 找不到 master 的 binlog,导致同步失败;
3.其它一些操作不当导致的问题;

怎么reset mysql master

重置mysql主从同步(MySQL Reset Master-Slave Replication)
在mysql主从同步的过程中,可能会因为各种原因出现主库与从库不同步的情况,网上虽然有一些解决办法,但是有时很难彻底解决,重置主从服务器也许不是最快的办法,但却是最安全有效的。
下面将自己重置主从同步的步骤总结一下,以备不时之需。
master与slave均使用:centos6.0+mysql 5.1.61 ,假设有db1,db2两个数据库需要热备。
文中shell与mysql均使用root账号,在真实环境中,请根据情况更换。
1.停止slave服务器的主从同步
为了防止主从数据不同步,需要先停止slave上的同步服务。
STOP SLAVE;
2.对master服务器的数据库加锁
为了避免在备份的时候对数据库进行更新操作,必须对数据库加锁。
FLUSH TABLES WITH READ LOCK;
如果是web服务器也可以关闭apache或nginx服务,效果也是一样的。

3.备份master上的数据
mysqldump -u root -p -databases db1 db2 > bak.sql
4.重置master服务
RESET MASTER;
这个是重置master的核心语法,看一下官方解释。
RESET MASTER removes all binary log files that are listed in the index file, leaving only a single, empty binary log file with a numeric suffix of .000001, whereas the numbering is not reset by PURGE BINARY LOGS.
RESET MASTER is not intended to be used while any replication slaves are running. The behavior. of RESET MASTER when used while slaves are running is undefined (and thus unsupported), whereas PURGE BINARY LOGS may be safely used while replication slaves are running.
大概的意思是RESET MASTER将删除所有的二进制日志,创建一个.000001的空日志。RESET MASTER并不会影响SLAVE服务器上的工作状态,所以盲目的执行这个命令会导致slave找不到master的binlog,造成同步失败。
但是我们就是要重置同步,所以必须执行它。
5.对master服务器的数据库解锁
UNLOCK TABLES;
如果你停止了apache或nginx,请开启它们

6.将master上的备份文件拷贝到slave服务器上
大可不必用WinScp先下载到本地再上传到slave上,可以直接使用scp命令在服务器间拷贝,速度更快。
scp -r root@XXX.XXX.XXX.XXX:/root/bak.sql ./
7.删除slave服务器上的旧数据
删除前,请先确认该备份的是否都备份了。
DROP DATABASE db1;
DROP DATABASE db2;
8.导入数据
SOURCE /root/bak.sql;
9.重置slave服务
RESET SLAVE;
还是看一下官方解释
RESET SLAVE makes the slave forget its replication position in the master's binary log. This statement is meant to be used for a clean start: It deletes the master.info and relay-log.info files, all the relay log files, and starts a new relay log file. To use RESET SLAVE, the slave replication threads must be stopped (use STOP SLAVE if necessary).
大概意思是,RESET SLAVE将清除slave上的同步位置,删除所有旧的同步日志,使用新的日志重新开始,这正是我们想要的。需要注意的是,必须先停止slave服务(STOP SLAVE),我们已经在第一步停止了它。
10.开启slave服务
START SLAVE;
大功告成,SHOW SLAVE STATUS\G 检查同步状态,一切正常。
参考技术A   reset master以后会删除之前的二进制日志,生成新的日志文件,这个时候为了以防万一,需要用mysqldump或者其他备份工具对你的数据库做完全备份,这样出现问题就可以用完全备份以及后面的二进制日志做居于时间点的恢复了。本回答被提问者和网友采纳 参考技术B 回答

1. 执行STOP SLAVE语句 2. 使用SHOW STATUS检查slave_open_temp_tables变量的值 3. 如果值为0,使用mysqladmin shutdown命令关闭从服务器 4. 如果值不为0,用START SLAVE重启从服务器线程 slave_open_temp_tables值显示,当前slave创建了多少临时表,注意由client显示创建的 即便是这样,在使用临时表的场景下,如果服务器宕机,将遇到不可预知的问题。 所以比较保险的做法是,创建实体表,虽然会由于分配的文件刷新到磁盘。

以上是关于mysql reset master 有风险吗的主要内容,如果未能解决你的问题,请参考以下文章

怎么reset mysql master

怎么reset mysql master

mysql主从复制重置操作--reset master, reset slave

关于MySQL的reset master和reset slave

RESET MASTER和RESET SLAVE使用场景和说明

mysql双主使用reset master清除日志要小心