SLAVE爲何一直不動了

導讀

遇到SLAVE延遲很大,binlog apply position一直不動的狀況如何排查?mysql

問題描述

收到SLAVE延遲時間一直很大的報警,因而檢查一下SLAVE狀態(無關狀態我給隱去了):sql

         Slave_IO_State: Waiting for master to send event         Master_Log_File: mysql-bin.000605     Read_Master_Log_Pos: 1194          Relay_Log_File: mysql-relay-bin.003224           Relay_Log_Pos: 295105   Relay_Master_Log_File: mysql-bin.000604        Slave_IO_Running: Yes       Slave_SQL_Running: Yes              Last_Errno: 0              Last_Error:     Exec_Master_Log_Pos: 294959         Relay_Log_Space: 4139172581   Seconds_Behind_Master: 10905

能夠看到,延遲確實很大,並且從屢次show slave status的結果來看,發現binlog的position一直不動。session

    Read_Master_Log_Pos: 1194          Relay_Log_File: mysql-relay-bin.003224           Relay_Log_Pos: 295105   Relay_Master_Log_File: mysql-bin.000604     Exec_Master_Log_Pos: 294959         Relay_Log_Space: 4139172581

從processlist的中也看不出來有什麼不對勁的SQL在跑:app

******************** 1. row ******************     Id: 16273070   User: system user   Host:     db: NULL Command: Connect   Time: 4828912  State: Waiting for master to send event   Info: NULL ********************* 2. row *****************     Id: 16273071   User: system user   Host:     db: NULL Command: Connect   Time: 9798  State: Reading event from the relay log   Info: NULL

在master上查看相應binlog,確認都在幹神馬事:spa

[yejr@imysql.com]# mysqlbinlog -vvv --base64-output=decode-rows -j 294959 mysql-bin.000604 | more /*!40019 SET @@session.max_insert_delayed_threads=0*/; /*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/; DELIMITER /*!*/; **# at 294959** #160204  6:16:30 server id 1  end_log_pos 295029     **Query    thread_id=461151**    **exec_time=2144**    error_code=0 SET TIMESTAMP=1454537790/*!*/; SET @@session.pseudo_thread_id=461151/*!*/; SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/; SET @@session.sql_mode=0/*!*/; SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1/*!*/; /*!\C latin1 *//*!*/; SET @@session.character_set_client=8,@@session.collation_connection=8,@@session.collation_server=33/*!*/; SET @@session.lc_time_names=0/*!*/; SET @@session.collation_database=DEFAULT/*!*/; BEGIN /*!*/; # at 295029 # at 295085 # at 296040 # at 297047 # at 298056 # at 299068 # at 300104

上面這段內容的幾個關鍵信息:線程

# at 294959   — binlog起點
thread_id=461151    — master上執行的線程ID
exec_time=2144    — 該事務執行總耗時code

再往下看都是一堆的binlog position信息,經過這種方式可讀性不強,咱們換一種姿式看看:server

[yejr@imysql.com (test)]> show binlog events in 'mysql-bin.000604' from 294959 limit 10; +------------------+--------+-------------+-----------+-------------+----------------------------+ | Log_name         | Pos    | Event_type  | Server_id | End_log_pos | Info                       | +------------------+--------+-------------+-----------+-------------+----------------------------+ | mysql-bin.000604 | 294959 | Query       |         1 |      295029 | BEGIN                      | | mysql-bin.000604 | 295029 | Table_map   |         1 |      295085 | table_id: 84 (bacula.File) | | mysql-bin.000604 | 295085 | Delete_rows |         1 |      296040 | table_id: 84               | | mysql-bin.000604 | 296040 | Delete_rows |         1 |      297047 | table_id: 84               | | mysql-bin.000604 | 297047 | Delete_rows |         1 |      298056 | table_id: 84               | | mysql-bin.000604 | 298056 | Delete_rows |         1 |      299068 | table_id: 84               | | mysql-bin.000604 | 299068 | Delete_rows |         1 |      300104 | table_id: 84               | | mysql-bin.000604 | 300104 | Delete_rows |         1 |      301116 | table_id: 84               | | mysql-bin.000604 | 301116 | Delete_rows |         1 |      302147 | table_id: 84               | | mysql-bin.000604 | 302147 | Delete_rows |         1 |      303138 | table_id: 84               |

+—————————+————+——————-+—————-+——————-+——————————————+事務

能夠看到,這個事務不幹別的,一直在刪除數據。
這是一個Bacula備份系統,會天天自動刪除一個月前的過時數據。
事實上,這個事務確實很是大,從binlog的294959開始,一直到這個binlog結束4139169218,一直都是在幹這事,總共大概有3.85G的binlog要等着apply。ssl

-rw-rw---- 1 mysql mysql 1.1G Feb  3 03:07 mysql-bin.000597 -rw-rw---- 1 mysql mysql 1.1G Feb  3 03:19 mysql-bin.000598 -rw-rw---- 1 mysql mysql 2.1G Feb  3 03:33 mysql-bin.000599 -rw-rw---- 1 mysql mysql 1.4G Feb  3 03:45 mysql-bin.000600 -rw-rw---- 1 mysql mysql 1.8G Feb  3 04:15 mysql-bin.000601 -rw-rw---- 1 mysql mysql 1.3G Feb  3 04:53 mysql-bin.000602 -rw-rw---- 1 mysql mysql 4.5G Feb  4 06:16 mysql-bin.000603 -rw-rw---- 1 mysql mysql 3.9G Feb  4 06:52 mysql-bin.000604 -rw-rw---- 1 mysql mysql 1.2K Feb  4 06:52 mysql-bin.000605

能夠看到上面的歷史binlog,個別狀況下,一個事務裏一次性要刪除數據量太大了,致使binlog文件遠超預設的1G,最大的達到4.5G之多。

怎麼解決

因爲這是Bacula備份系統內置生成的大事務,除非去修改它的源碼,不然沒有太好的辦法。

對於咱們通常的應用而言,最好是攢夠必定操做後,就先提交一下事務,好比刪除幾千條記錄後提交一次,而不是像本例這樣,一個刪除事務消耗了將近3.9G的binlog日質量,這種就很是可怕了。

除了會致使SLAVE看起來一直不動之外,還可能會致使某些數據行(data rows)被長時間鎖定不釋放,而致使大量行鎖等待發生。

相關文章
相關標籤/搜索