MySQL主从复制之延迟型数据复制

   让MySQL拓扑中的从节点延迟适当的时间,可以帮助避免在主节点上发生的灾难性的错误。
   MASTER_DELAY这个属性指定SQL_THREAD会在从节点上暂定多长时间,时间以秒为单位。默认值为0,上限为68年。
mysql> stop slave;
Query OK, 0 rows affected (0.06 sec)
mysql> change master to master_delay=20;
Query OK, 0 rows affected (0.01 sec)
mysql> start slave;

点击(此处)折叠或打开

创新互联公司成都网站建设按需策划,是成都网站营销公司,为成都雨棚定制提供网站建设服务,有成熟的网站定制合作流程,提供网站定制设计服务:原型图制作、网站创意设计、前端HTML5制作、后台程序开发等。成都网站维护热线:18982081108

  1. mysql> stop slave;
  2. Query OK, 0 rows affected (0.01 sec)

  3. mysql> change master to master_delay=20 ;
  4. Query OK, 0 rows affected (0.02 sec)

  5. mysql> start slave;
  6. Query OK, 0 rows affected (0.02 sec)

  7. mysql> show slave status \G
  8. *************************** 1. row ***************************
  9.                Slave_IO_State: Waiting for master to send event
  10.                   Master_Host: 192.168.8.57
  11.                   Master_User: repl
  12.                   Master_Port: 3306
  13.                 Connect_Retry: 10
  14.               Master_Log_File: mysql-bin.000021
  15.           Read_Master_Log_Pos: 154
  16.                Relay_Log_File: relay-log.000002
  17.                 Relay_Log_Pos: 320
  18.         Relay_Master_Log_File: mysql-bin.000021
  19.              Slave_IO_Running: Yes
  20.             Slave_SQL_Running: Yes
  21.               Replicate_Do_DB:
  22.           Replicate_Ignore_DB:
  23.            Replicate_Do_Table:
  24.        Replicate_Ignore_Table:
  25.       Replicate_Wild_Do_Table:
  26.   Replicate_Wild_Ignore_Table:
  27.                    Last_Errno: 0
  28.                    Last_Error:
  29.                  Skip_Counter: 0
  30.           Exec_Master_Log_Pos: 154
  31.               Relay_Log_Space: 521
  32.               Until_Condition: None
  33.                Until_Log_File:
  34.                 Until_Log_Pos: 0
  35.            Master_SSL_Allowed: No
  36.            Master_SSL_CA_File: /usr/local/mysql/certs/ca-cert.pem
  37.            Master_SSL_CA_Path:
  38.               Master_SSL_Cert: /usr/local/mysql/certs/client-cert.pem
  39.             Master_SSL_Cipher:
  40.                Master_SSL_Key: /usr/local/mysql/certs/client-key.pem
  41.         Seconds_Behind_Master: 0
  42. Master_SSL_Verify_Server_Cert: No
  43.                 Last_IO_Errno: 0
  44.                 Last_IO_Error:
  45.                Last_SQL_Errno: 0
  46.                Last_SQL_Error:
  47.   Replicate_Ignore_Server_Ids:
  48.              Master_Server_Id: 1
  49.                   Master_UUID: 9ad24233-aeef-11e7-aa1b-080027768e58
  50.              Master_Info_File: mysql.slave_master_info
  51.                     SQL_Delay: 20
  52.           SQL_Remaining_Delay: NULL
  53.       Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
  54.            Master_Retry_Count: 86400
  55.                   Master_Bind:
  56.       Last_IO_Error_Timestamp:
  57.      Last_SQL_Error_Timestamp:
  58.                Master_SSL_Crl:
  59.            Master_SSL_Crlpath:
  60.            Retrieved_Gtid_Set:
  61.             Executed_Gtid_Set:
  62.                 Auto_Position: 0
  63.          Replicate_Rewrite_DB:
  64.                  Channel_Name:
  65.            Master_TLS_Version:
  66. 1 row in set (0.00 sec)
    可以看到SQL_Delay: 20
下边做一个测试:
在主节点对测试表做truncate

点击(此处)折叠或打开

  1. mysql> show tables;
  2. +----------------+
  3. | Tables_in_test |
  4. +----------------+
  5. | tb_admin |
  6. | tb_admin_bak |
  7. +----------------+
  8. 2 rows in set (0.00 sec)

  9. mysql> truncate table tb_admin_bak;
  10. Query OK, 0 rows affected (0.02 sec)
在从节点查看表信息

点击(此处)折叠或打开

  1. mysql> select count(*) from tb_admin_bak;
  2. +----------+
  3. | count(*) |
  4. +----------+
  5. | 1 |
  6. +----------+
  7. 1 row in set (0.02 sec)

  8. mysql> select count(*) from tb_admin_bak;
  9. +----------+
  10. | count(*) |
  11. +----------+
  12. | 1 |
  13. +----------+
  14. 1 row in set (0.00 sec)

  15. mysql> show full processlist \G
  16. *************************** 1. row ***************************
  17.      Id: 3
  18.    User: root
  19.    Host: localhost
  20.      db: test
  21. Command: Query
  22.    Time: 0
  23.   State: starting
  24.    Info: show full processlist
  25. *************************** 2. row ***************************
  26.      Id: 8
  27.    User: system user
  28.    Host:
  29.      db: NULL
  30. Command: Connect
  31.    Time: 334
  32.   State: Waiting for master to send event
  33.    Info: NULL
  34. *************************** 3. row ***************************
  35.      Id: 9
  36.    User: system user
  37.    Host:
  38.      db: NULL
  39. Command: Connect
  40.    Time: 100
  41.   State: Waiting until MASTER_DELAY seconds after master executed event
  42.    Info: NULL
  43. 3 rows in set (0.00 sec)
  44. mysql> select count(*) from tb_admin_bak;
  45. +----------+
  46. | count(*) |
  47. +----------+
  48. | 0 |
  49. +----------+
  50. 1 row in set (0.00 sec)
发现从节点此表数据刚开始并没有被清理,20S之后数据才被清理掉。

在主库删除测试表

点击(此处)折叠或打开

  1. mysql> drop table tb_admin_bak;
  2. Query OK, 0 rows affected (0.06 sec)

  3. mysql> show tables;
  4. +----------------+
  5. | Tables_in_test |
  6. +----------------+
  7. | tb_admin |
  8. +----------------+
  9. 1 row in set (0.00 sec)
在从库查看表是否存在

点击(此处)折叠或打开

  1. mysql> show tables;
  2. +----------------+
  3. | Tables_in_test |
  4. +----------------+
  5. | tb_admin |
  6. | tb_admin_bak |
  7. +----------------+
  8. 2 rows in set (0.00 sec)

  9. mysql> show tables;
  10. +----------------+
  11. | Tables_in_test |
  12. +----------------+
  13. | tb_admin |
  14. | tb_admin_bak |
  15. +----------------+
  16. 2 rows in set (0.00 sec)

  17. mysql> show tables;
  18. +----------------+
  19. | Tables_in_test |
  20. +----------------+
  21. | tb_admin |
  22. | tb_admin_bak |
  23. +----------------+
  24. 2 rows in set (0.00 sec)

  25. mysql> show tables;
  26. +----------------+
  27. | Tables_in_test |
  28. +----------------+
  29. | tb_admin |
  30. | tb_admin_bak |
  31. +----------------+
  32. 2 rows in set (0.00 sec)

  33. mysql> show tables;
  34. +----------------+
  35. | Tables_in_test |
  36. +----------------+
  37. | tb_admin |
  38. | tb_admin_bak |
  39. +----------------+
  40. 2 rows in set (0.00 sec)

  41. mysql> show tables;
  42. +----------------+
  43. | Tables_in_test |
  44. +----------------+
  45. | tb_admin |
  46. | tb_admin_bak |
  47. +----------------+
  48. 2 rows in set (0.00 sec)

  49. mysql> show tables;
  50. +----------------+
  51. | Tables_in_test |
  52. +----------------+
  53. | tb_admin |
  54. | tb_admin_bak |
  55. +----------------+
  56. 2 rows in set (0.00 sec)

  57. mysql> show tables;
  58. +----------------+
  59. | Tables_in_test |
  60. +----------------+
  61. | tb_admin |
  62. +----------------+
  63. 1 row in set (0.00 sec)

  64. mysql> show tables;
  65. +----------------+
  66. | Tables_in_test |
  67. +----------------+
  68. | tb_admin |
  69. +----------------+
  70. 1 row in set (0.00 sec)
一段时间之后,测试表才被删除。





文章标题:MySQL主从复制之延迟型数据复制
本文地址:http://csdahua.cn/article/jdoohh.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流