主库一直模拟插入数据
1.关闭slave 复制进程
mysql> stop slave;
Query OK, 0 rows affected (0.00 sec)
2.主库备份需要恢复的表
3.恢复从库到指定的点
mysql> start slave until master_log_file='on.000001',master_log_pos=38848;
Query OK, 0 rows affected, 1 warning (0.00 sec)
------这一步主要是为了同步断开slave到备份完表这一段时间内其它表产生的数据
直到slq-thread为no,这期间的错误一律跳过即可,可用如下命令
stop slave;set global sql_slave_skip_counter=1;start slave;
4 在slave机器上导入备份文件
[root@node2 ~]# mysql -uroot -pESBecs00 hd<test2.sq
5开启同步即可
</test2.sq
<test2.sq
<test2.sq
具体步骤如下:
</test2.sq
-
[root@node1 ~]# vi tt.sh
-
#!/bin/bash
-
for ((i=1;i<=1000;i++))
-
do
-
mysql -uroot -pESBecs00 -e "insert into test1 values($i,'chen$i')" hd
-
mysql -uroot -pESBecs00 -e "insert into test2 values($i,'chen$i')" hd
-
sleep 0.5
- done
1.关闭slave 复制进程
mysql> stop slave;
Query OK, 0 rows affected (0.00 sec)
2.主库备份需要恢复的表
-
[root@node1 ~]# mysqldump -uroot -pESBecs00 --master-data=2 hd test2 >test2.sql
-
[root@node1 ~]# more test2.sql
-
-- MySQL dump 10.13 Distrib 5.5.50, for Linux (i686)
-
--
-
-- Host: localhost Database: hd
-
-- ------------------------------------------------------
-
-- Server version 5.5.50-log
-
-
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
-
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
-
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
-
/*!40101 SET NAMES utf8 */;
-
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
-
/*!40103 SET TIME_ZONE='+00:00' */;
-
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
-
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
-
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
-
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
-
-
--
-
-- Position to start replication or point-in-time recovery from
-
--
-
-
-- CHANGE MASTER TO MASTER_LOG_FILE='on.000001', MASTER_LOG_POS=38848; --一定要开启master-data几下备份点信息
-
-
--
-
-- Table structure for table `test2`
- --
3.恢复从库到指定的点
mysql> start slave until master_log_file='on.000001',master_log_pos=38848;
Query OK, 0 rows affected, 1 warning (0.00 sec)
------这一步主要是为了同步断开slave到备份完表这一段时间内其它表产生的数据
直到slq-thread为no,这期间的错误一律跳过即可,可用如下命令
stop slave;set global sql_slave_skip_counter=1;start slave;
4 在slave机器上导入备份文件
[root@node2 ~]# mysql -uroot -pESBecs00 hd<test2.sq
5开启同步即可
点击(此处)折叠或打开
-
mysql> start slave;
-
Query OK, 0 rows affected (0.00 sec)
-
-
mysql> show slave status\G;
-
*************************** 1. row ***************************
-
Slave_IO_State: Waiting for master to send event
-
Master_Host: 192.168.6.114
-
Master_User: repl
-
Master_Port: 3306
-
Connect_Retry: 60
-
Master_Log_File: on.000001
-
Read_Master_Log_Pos: 137848
-
Relay_Log_File: mysqld-relay-bin.000003
-
Relay_Log_Pos: 123785
-
Relay_Master_Log_File: on.000001
-
Slave_IO_Running: Yes
- Slave_SQL_Running: Yes
</test2.sq
<test2.sq
GTID模式下参考:</test2.sq
<test2.sq- c.新的until条件
-
5.6提供了新的util condition,可以根据GTID来决定备库复制执行到的位置
-
SQL_BEFORE_GTIDS:在指定的GTID之前停止复制
-
SQL_AFTER_GTIDS :在指定的GTID之后停止复制
-
判断函数为Relay_log_info::is_until_satisfied
- 详细文档见: http://dev.mysql.com/doc/refman/5.6/en/start-slave.html
具体步骤如下:
- 1 模拟脚本写入---同上
- 2 stop slave
- 3 mysqldump test2 几下gtid的信息SET @@GLOBAL.GTID_PURGED='8a0d06d7-91cb-11e5-843b-00163ec09859:1-1973';
-
4 start slave until SQL_after_GTIDS='8a0d06d7-91cb-11e5-843b-00163ec09859:1-1973';
-
Slave_IO_Running: Yes
Slave_SQL_Running: No
-
Retrieved_Gtid_Set: 6c8a10ed8a0d06d7-91cb-11e5-843b-00163ec09859:3931
- Executed_Gtid_Set: 6c8a10ed8a0d06d7-91cb-11e5-843b-00163ec09859:1-1973 ---就是到这个点时,slave_sql线程会关闭
- Auto_Position: 1
-
Slave_IO_Running: Yes
- 5 导入 备份的test2文件(注释掉gtid那行)
-
- 6 start slave
- 检查
- (root@127.0.0.1) [gggg]> select * from test1
- 。。。
- 。。。
-
| 379 | chen379 |
+-----+---------+
379 rows in set (0.00 sec) ---数量一致,数据未丢失
- (root@127.0.0.1) [gggg]> select * from test1
-
| 406 | chen406 |
+-----+---------+
406 rows in set (0.00 sec) ---数量一致,数据未丢失
</test2.sq
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29096438/viewspace-2121676/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29096438/viewspace-2121676/
本文介绍了一种在MySQL中进行数据恢复和同步的方法,包括使用脚本模拟数据插入、停止和启动复制进程、备份和恢复指定表数据的具体步骤。此外还介绍了如何利用GTID进行精确的复制位置控制。
4592

被折叠的 条评论
为什么被折叠?



