当前位置:Gxlcms > 数据库问题 > MySQL复制的管理和维护

MySQL复制的管理和维护

时间:2021-07-01 10:21:17 帮助过:2人阅读

1.查看主库

mysql> show master status;

  1. mysql> show master status;
  2. +------------------+-----------+--------------+------------------+
  3. | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
  4. +------------------+-----------+--------------+------------------+
  5. | mysql-bin.000013 | 971159980 | | |
  6. +------------------+-----------+--------------+------------------+
  7. 1 row in set (0.00 sec)

mysql> show master logs;

  1. mysql> show master logs;
  2. +------------------+------------+
  3. | Log_name | File_size |
  4. +------------------+------------+
  5. | mysql-bin.000011 | 1073949250 |
  6. | mysql-bin.000012 | 1073751139 |
  7. | mysql-bin.000013 | 971159980 |
  8. +------------------+------------+
  9. 3 rows in set (0.00 sec)

mysql> show binlog events in ‘mysql-bin.000013‘ from 971245404;

  1. mysql> show binlog events in ‘mysql-bin.000013‘ from 971245404;
  2. +------------------+-----------+-------------+-----------+-------------+-----------------------------------------+
  3. | Log_name | Pos | Event_type | Server_id | End_log_pos | Info |
  4. +------------------+-----------+-------------+-----------+-------------+-----------------------------------------+
  5. | mysql-bin.000013 | 971245404 | Query | 1 | 971245474 | BEGIN |
  6. | mysql-bin.000013 | 971245474 | Table_map | 1 | 971245651 | table_id: 175 (attend.sys_user) |
  7. | mysql-bin.000013 | 971245651 | Update_rows | 1 | 971246116 | table_id: 175 flags: STMT_END_F |
  8. | mysql-bin.000013 | 971246116 | Table_map | 1 | 971246185 | table_id: 176 (attend.sys_user_branch) |
  9. | mysql-bin.000013 | 971246185 | Write_rows | 1 | 971246266 | table_id: 176 flags: STMT_END_F |
  10. | mysql-bin.000013 | 971246266 | Table_map | 1 | 971246335 | table_id: 176 (attend.sys_user_branch) |
  11. | mysql-bin.000013 | 971246335 | Delete_rows | 1 | 971246416 | table_id: 176 flags: STMT_END_F |
  12. | mysql-bin.000013 | 971246416 | Xid | 1 | 971246443 | COMMIT /* xid=3065249192 */ | |
  13. +------------------+-----------+-------------+-----------+-------------+-----------------------------------------+
  14. 8 rows in set (0.00 sec)

 

2.查看复制库延迟

mysql> show slave status\G

  1. mysql> show slave status\G
  2. *************************** 1. row ***************************
  3. Slave_IO_State: Waiting for master to send event
  4. Master_Host: 192.168.10.106
  5. Master_User: repl
  6. Master_Port: 3306
  7. Connect_Retry: 60
  8. Master_Log_File: mysql-bin.000013
  9. Read_Master_Log_Pos: 971434196
  10. Relay_Log_File: mysql-relay-bin.000002
  11. Relay_Log_Pos: 126333146
  12. Relay_Master_Log_File: mysql-bin.000013
  13. Slave_IO_Running: Yes
  14. Slave_SQL_Running: Yes
  15. Replicate_Do_DB:
  16. Replicate_Ignore_DB:
  17. Replicate_Do_Table:
  18. Replicate_Ignore_Table:
  19. Replicate_Wild_Do_Table:
  20. Replicate_Wild_Ignore_Table:
  21. Last_Errno: 0
  22. Last_Error:
  23. Skip_Counter: 0
  24. Exec_Master_Log_Pos: 971434196
  25. Relay_Log_Space: 126333302
  26. Until_Condition: None
  27. Until_Log_File:
  28. Until_Log_Pos: 0
  29. Master_SSL_Allowed: No
  30. Master_SSL_CA_File:
  31. Master_SSL_CA_Path:
  32. Master_SSL_Cert:
  33. Master_SSL_Cipher:
  34. Master_SSL_Key:
  35. Seconds_Behind_Master: 0
  36. Master_SSL_Verify_Server_Cert: No
  37. Last_IO_Errno: 0
  38. Last_IO_Error:
  39. Last_SQL_Errno: 0
  40. Last_SQL_Error:
  41. Replicate_Ignore_Server_Ids:
  42. Master_Server_Id: 1
  43. 1 row in set (0.00 sec)

Seconds_Behind_Master:

·显示备库延迟,但不准确

·将服务器当前的时间戳与二进制日志中的事件时间戳相对比,所以只有在执行复制事件时才能报告延迟

·如果复制线程没有运行,延迟报告为null

·有时复制发生错误时,该参数为显示为0,而不是显示错误

·有时,即使复制线程正常运行,也不能估算延迟,而是显示0或null

·大事务会导致延迟波动

 

检测延迟比较好的方法是:使用heartbeat record

 

3. 确认主备是否一致

mysql没有内建方法来确认主备是否一致。checksum table可以校验数据,但是复制正在进行时,这种方法不可行。

可以使用percona提供的pt-table-checksum来校验主备数据是否一致。(结合pt-table-sync使用,重新同步数据)

 

MySQL复制的管理和维护

标签:

人气教程排行