SHOW SLAVE STATUS 詳解
如上所述,每個master/slave上都有3個執行緒。每個master上有多個執行緒,它為每個slave連線都建立一個執行緒,每個slave只有I/O和SQL執行緒。
show slave master 用於提供有關從屬伺服器執行緒的關鍵引數的資訊
mysql> show slave status \G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 172.17.2.40
Master_User: photorepl
Master_Port: 4331
Connect_Retry: 60
Master_Log_File: mysql-bin.005502
Read_Master_Log_Pos: 64401238
Relay_Log_File: mysqld-relay-bin.015418
Relay_Log_Pos: 13456757
Relay_Master_Log_File: mysql-bin.005152
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB: mysql
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table: photo.%
Replicate_Wild_Ignore_Table: mysql.%
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 13456620
Relay_Log_Space: 36764898503
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 249904
××××××××××××××××××××××××××××××××××××××××××××××××××××××××××
SHOW SLAVE STATUS會返回以下欄位:
Slave_IO_State
SHOW PROCESSLIST輸出的State欄位的複製。SHOW PROCESSLIST用於從屬I/O執行緒。如果執行緒正在試圖連線到主伺服器,正在等待來自主伺服器的時間或正在連線到主伺服器等,本語句會通知您
Master_User
被用於連線主伺服器的當前使用者。
Master_Port
當前的主伺服器介面。
Connect_Retry
--master-connect-retry選項的當前值
Master_Log_File
I/O執行緒當前正在讀取的主伺服器二進位制日誌檔案的名稱。
Read_Master_Log_Pos
在當前的主伺服器二進位制日誌中,I/O執行緒已經讀取的位置。
Relay_Log_File
SQL執行緒當前正在讀取和執行的中繼日誌檔案的名稱。
Relay_Log_Pos
在當前的中繼日誌中,SQL執行緒已讀取和執行的位置。
Relay_Master_Log_File
由SQL執行緒執行的包含多數近期事件的主伺服器二進位制日誌檔案的名稱。
Slave_IO_Running
I/O執行緒是否被啟動併成功地連線到主伺服器上。
Slave_SQL_Running
SQL執行緒是否被啟動。
Replicate_Do_DB,Replicate_Ignore_DB
使用--replicate-do-db和--replicate-ignore-db選項指定的資料庫清單。
Replicate_Do_Table,Replicate_Ignore_Table,Replicate_Wild_Do_Table,Replicate_Wild_Ignore_Table
使用--replicate-do-table,--replicate-ignore-table,--replicate-wild-do-table和--replicate-wild-ignore_table選項指定的表清單。
Last_Errno,Last_Error
被多數最近被執行的查詢返回的錯誤數量和錯誤訊息。錯誤數量為0並且訊息為空字串意味著“沒有錯誤”。如果Last_Error值不是空值,它也會在從屬伺服器的錯誤日誌中作為訊息顯示。
舉例說明:
Last_Errno: 1051
Last_Error: error 'Unknown table 'z'' on query 'drop table z'
該訊息指示,表z曾經存在於在主伺服器中並已被取消了,但是它沒有在從屬伺服器中存在過,因此對於從屬伺服器,DROP TABLE失敗。(舉例說明,在設定複製時,如果您忘記了把此表複製到從屬伺服器中,則這有可能發生。)
Skip_Counter
最近被使用的用於SQL_SLAVE_SKIP_COUNTER的值。
Exec_Master_Log_Pos
來自主伺服器的二進位制日誌的由SQL執行緒執行的上一個時間的位置(Relay_Master_Log_File)。在主伺服器的二進位制日誌中的(Relay_Master_Log_File,Exec_Master_Log_Pos)對應於在中繼日誌中的(Relay_Log_File,Relay_Log_Pos)。
Relay_Log_Space
所有原有的中繼日誌結合起來的總大小。
Until_Condition,Until_Log_File,Until_Log_Pos
在START SLAVE語句的UNTIL子句中指定的值。
Until_Condition具有以下值:
如果沒有指定UNTIL子句,則沒有值
如果從屬伺服器正在讀取,直到達到主伺服器的二進位制日誌的給定位置為止,則值為Master
如果從屬伺服器正在讀取,直到達到其中繼日誌的給定位置為止,則值為Relay
Until_Log_File和Until_Log_Pos用於指示日誌檔名和位置值。日誌檔名和位置值定義了SQL執行緒在哪個點中止執行。
Master_SSL_Allowed,Master_SSL_CA_File,Master_SSL_CA_Path,Master_SSL_Cert,Master_SSL_Cipher,Master_SSL_Key
這些欄位顯示了被從屬伺服器使用的引數。這些引數用於連線主伺服器。
Master_SSL_Allowed具有以下值:
如果允許對主伺服器進行SSL連線,則值為Yes
如果不允許對主伺服器進行SSL連線,則值為No
如果允許SSL連線,但是從屬伺服器沒有讓SSL支援被啟用,則值為Ignored。
與SSL有關的欄位的值對應於--master-ca,--master-capath,--master-cert,--master-cipher和--master-key選項的值。
Seconds_Behind_Master
本欄位是從屬伺服器“落後”多少的一個指示。當從屬SQL執行緒正在執行時(處理更新),本欄位為在主伺服器上由此執行緒執行的最近的一個事件的時間標記開始,已經過的秒數。當此執行緒被從屬伺服器I/O執行緒趕上,並進入閒置狀態,等待來自I/O執行緒的更多的事件時,本欄位為零。總之,本欄位測量從屬伺服器SQL執行緒和從屬伺服器I/O執行緒之間的時間差距,單位以秒計。
如果主伺服器和從屬伺服器之間的網路連線較快,則從屬伺服器I/O執行緒會非常接近主伺服器,所以本欄位能夠十分近似地指示,從屬伺服器SQL執行緒比主伺服器落後多少。如果網路較慢,則這種指示不準確;從屬SQL執行緒經常會趕上讀取速度較慢地從屬伺服器I/O執行緒,因此,Seconds_Behind_Master經常顯示值為0。即使I/O執行緒落後於主伺服器時,也是如此。換句話說,本列只對速度快的網路有用。
即使主伺服器和從屬伺服器不具有相同的時鐘,時間差計算也會起作用(當從屬伺服器I/O執行緒啟動時,計算時間差。並假定從此時以後,時間差保持不變)。如果從屬SQL執行緒不執行,或者如果從屬伺服器I/O執行緒不執行或未與主伺服器連線,則Seconds_Behind_Master為NULL(意義為“未知”)。舉例說明,如果在重新連線之前,從屬伺服器I/O執行緒休眠了master-connect-retry秒,則顯示NULL,因為從屬伺服器不知道主伺服器正在做什麼,也不能有把握地說落後多少。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28371090/viewspace-764532/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL show status 命令詳解MySql
- [MySQL進階之路][No.0002] SHOW SLAVE STATUSMySql
- MySQL主從複製中的“show slave status”詳細含義MySql
- MySQL:show slave status 關鍵值和MGRrelay log的清理策略MySql
- show engine innodb status 輸出結果解讀
- MySQL的show engine innodb statusMySql
- git status命令詳解Git
- [原創] How to show chinese character in Git StatusGit
- show engine innodb status操作解析之一
- git show-branch命令詳解Git
- mysql檢視儲存過程show procedure status;MySql儲存過程
- HTTP Status 404 的詳細解決思路HTTP
- MySQL:5.6 大事務show engine innodb status故障一例MySql
- Percona 8.0.30中"show engine innodb status"導致coredump排查及分析
- 使用show engine innodb status 檢視記憶體使用情況記憶體
- Innodb: 自動開啟列印show engine status到err日誌
- 技術分享 | show engine innodb status中Pages flushed up to 的含義
- HTTP協議狀態碼詳解(HTTP Status Code)HTTP協議
- MySQ 資料庫主從同步安裝與配置詳解(Master/Slave)資料庫主從同步AST
- CentOS中MySQL5.6 資料庫主從(Master/Slave)同步安裝與配置詳解CentOSMySql資料庫AST
- JavaScript show()JavaScript
- show profiles
- Git(6)-- 記錄每次更新到倉庫(git clone、status、add、diff、commit、rm、mv命令詳解)GitMIT
- Input原始碼解讀——從"Show tabs"開始原始碼
- Check failed: status == CUDNN_STATUS_SUCCESS (4 vs. 0) CUDNN_STATUS_INTERNAL_ERRORAIDNNError
- MySQL複製跳過錯誤--slave_skip_errors、sql_slave_skip_counter、slave_exec_modeMySqlError
- JavaScript show() 方法JavaScript
- git show 命令Git
- slave-skip-errorsError
- jenkins 動態 slaveJenkins
- [20210723]adrci show 'No ADR base is set' 解決辦法.txt
- 【MySQL】六、常見slave 延遲原因以及解決方法MySql
- The slave I/O thread stops because master and slave have equal MySQL server UUIDthreadASTMySqlServerUI
- TIC Read Status
- git status 命令Git
- sql_slave_skip_counterSQL
- WPF ProgressBar show value
- show_space(轉)
- git show命令用法Git