mysql5.6开始支持延时复制,默认master_delay为0秒,

CHANGE MASTER TO MASTER_DELAY = N;

表示延时N秒

原理:延时复制的本质是sql_thread需要等待延时时间之后才能执行。


延时复制适用场景:

(1)防止主库误操作,在复制同步之前,可以停止同步

(2)用作测试

(3)用来检查数据库以前的数据

reset slave会把master_delay清零;


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
创建一个延时复制:
slave:
root@localhost [testdb]>stop slave;
root@localhost [testdb]>change master  to  master_delay=60;
root@localhost [testdb]>start slave;
 
root@localhost [testdb]>show slave status\G
......
                     SQL_Delay: 60   --延时时间
           SQL_Remaining_Delay: 56            --剩余时间
       Slave_SQL_Running_State: Waiting until MASTER_DELAY seconds  after  master executed event    --等待延时
......
master:
root@localhost [testdb]> delete  from  t1  where  c1=4;
 
slave:
root@localhost [testdb]> select  from  t1;
+ ----+------+
| c1 | c2   |
+ ----+------+
|  1 | aaa  |
|  2 | bbb  |
|  3 | ccc  |
|  4 | ddd  |
+ ----+------+
 
root@localhost [testdb]>show processlist;
+ ----+-------------+-----------+--------+---------+------+----------------------------------------------------------------+------------------+
| Id |  User         | Host      | db     | Command |  Time  | State                                                          | Info             |
+ ----+-------------+-----------+--------+---------+------+----------------------------------------------------------------+------------------+
| 26 | root        | localhost | testdb | Query   |    0 | starting                                                       | show processlist |
| 27 | system  user  |           |  NULL    Connect  |  345 | Waiting  for  master  to  send event                               |  NULL              |
| 28 | system  user  |           |  NULL    Connect  |   10 | Waiting until MASTER_DELAY seconds  after  master executed event |  NULL              |
+ ----+-------------+-----------+--------+---------+------+----------------------------------------------------------------+------------------+
 
#在没有达到60秒之前查看relay-log日志,发现已经写入relay-lo中,说明延时是阻塞SQL_thread线程
[root@Darren1 data]# mysqlbinlog -vv  --base64-output=decode-rows relay-bin.000003
BEGIN
/*!*/;
at  452
#170409 22:12:27 server id 330622  end_log_pos 5624 CRC32 0x86f7edf4    Table_map: `testdb`.`t1` mapped  to  number 147
at  502
#170409 22:12:27 server id 330622  end_log_pos 5668 CRC32 0x697c52ed    Delete_rows:  table  id 147 flags: STMT_END_F
###  DELETE  FROM  `testdb`.`t1`
###  WHERE
###   @1=3 /*  INT  meta=0 nullable=0 is_null=0 */
###   @2= 'ccc'  /* VARSTRING(30) meta=30 nullable=1 is_null=0 */
 
root@localhost [testdb]> select  from  t1;
+ ----+------+
| c1 | c2   |
+ ----+------+
|  1 | aaa  |
|  2 | bbb  |
|  3 | ccc  |
+ ----+------+