怎么reset mysql master

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么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 执行命令:

[root@bogon ~]# mysql -uroot -p -e "reset master;"
Enter password:
[root@bogon ~]#本回答被提问者采纳
参考技术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 slave

本文介绍reset master, reset slave的作用。

reset master

在master上执行

mysql > RESET MASTER

作用包括:

  • 删除binlog索引文件中列出的所有binlog文件
  • 清空binlog索引文件
  • 创建一个新的binlog文件

reset slave

在slave上执行

mysql > RESET SLAVE

作用包括:

  • 清除slave 复制时的master binlog的位置
  • 清空master info, relay log info
  • 删除所有的relay log文件,并创建一个新的relay log文件。
  • 重置复制延迟(CHANGE MASTER TO 的 MASTER_DELAY参数指定的)为0。

另外,
RESET SLAVE 不会改变gtid_executed or gtid_purged.
RESET SLAVE 不会改变复制连接使用的参数,例如master host, master port, master user, or master password

如果要重置这些连接参数,需要使用命令

mysql > RESET SLAVE ALL

重置操作之后,就需要使用 CHANGE MASTER TO 重新指定复制连接参数。

参考

change master to
show slave status
reset slave
reset master






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

MySQL NDB Cluster 和 Master Master 复制

mysql 设置不了短串密码怎么办 You must reset your password using ALTER USER statement before executing this stat

MySQL You must reset your password using ALTER USE

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

MySQL中RESET SLAVE和RESET MASTER的区别

关于MySQL的reset master和reset slave