ProxySQL官檔翻譯__19_Monitor_Module

19_Monitor_Module

備註:文章編寫時間201904-201905期間,後續官方在github的更新沒有被寫入mysql

1、監控功能模塊[Monitor Module]

本節重點介紹Monitor v1.2.1,由於它引入了與v1.2.0相比的多項改進。git

已刪除的未使用或已棄用的變量:
mysql-monitor_query_variables
mysql-monitor_query_status
mysql-monitor_timer_cachedgithub

目前還沒有使用的變量:
mysql-monitor_query_interval
mysql-monitor_query_timeoutsql

2、概述[Overview]

監控模塊負責對後端進行一系列檢查。它目前支持4種類型的檢查:
1)connect ==>它鏈接到全部後端MySQL服務,成功/失敗將記錄在表mysql_server_connect_log中;
2)ping ==>它ping到全部後端的MySQL服務,並在表 mysql_server_ping_log 中記錄成功/失敗。若是丟失心跳的次數超過 mysql-monitor_ping_max_failures 值,則向MySQL_Hostgroups_Manager發送信號以終止全部鏈接;
3)replication lag ==>它將檢查配置了 max_replication_lag 大於0的全部後端MySQL的 Seconds_Behind_Master 值,並將檢查結果記錄在表 mysql_server_replication_lag_log 中。若是 Seconds_Behind_Master > max_replication_lag 則服務器被忽略,直到 Seconds_Behind_Master < max_replication_lag;
4)read only ==>它檢查表 mysql_replication_hostgroups 內記錄的主機組中全部主機的 read_only 參數值,並將檢查結果在記錄表mysql_server_read_only_log中。後端

3、參數[Variables]

A-常規參數:

1)mysql-monitor_username
指定Monitor模塊用於鏈接後端MySQL的用戶名。
用戶只須要USAGE權限便可鏈接,以便用於執行ping和read_only檢查。若是須要監視複製延遲,用戶還須要REPLICATION CLIENT權限。服務器

2)mysql-monitor_password
mysql-monitor_username用戶的密碼ide

3)mysql-monitor_enabled
它啓用或禁用MySQL Monitor。
因爲MySQL Monitor能夠直接干擾在Admin界面上執行的更改,所以該變量容許臨時禁用它。線程

B-鏈接參數:

1)mysql-monitor_connect_interval
執行鏈接檢查的頻率,以毫秒爲單位。日誌

2)mysql-monitor_connect_timeout
鏈接超時時間(以毫秒爲單位)。
當前實現中將此值四捨五入到小於或等於原始間隔的整數秒,最小值爲1秒。server

C-Ping 參數:

1)mysql-monitor_ping_interval
執行ping檢查的頻率,以毫秒爲單位

2)mysql-monitor_ping_timeout
Ping超時時間(以毫秒爲單位)。

3)mysql-monitor_ping_max_failures
若是主機連續丟失了 mysql-monitor_ping_max_failures 次ping,則MySQL_Monitor會通知MySQL_Hostgroup_Manager,告知該節點沒法訪問,應當即終止全部鏈接。
在添加服務器信息後,MySQL_Monitor將第一個發起嘗試鏈接以進行ping操做,所以檢測節點的時間多是如下兩種狀況之一:
mysql-monitor_ping_max_failures mysql-monitor_connect_timeout

mysql-monitor_ping_max_failures
mysql-monitor_ping_timeout

D-只讀參數:

1)mysql-monitor_read_only_interval
執行只讀檢查的頻率,以毫秒爲單位。

2)mysql-monitor_read_only_timeout
只讀檢查超時時間(以毫秒爲單位)

3)mysql-monitor_writer_is_also_reader
當節點將其read_only值從1更改成0時,此參數將指明該節點是否存在於兩個主機組中:
false :節點將在 writer_hostgroup 中移動並從 reader_hostgroup 中刪除;
true :節點將在 writer_hostgroup 中複製並保留在 reader_hostgroup 中;

E-複製延時參數:

1)mysql-monitor_replication_lag_interval
執行復制延遲檢查的頻率,以毫秒爲單位。

2)mysql-monitor_replication_lag_timeout
複製延遲檢查超時時間(以毫秒爲單位)。

F-其餘參數:

1)mysql-monitor_history
爲防止日誌表無限制地增加,Monitor Module將自動清除早於 mysql-monitor_history 毫秒的記錄。
因爲ping檢查依賴於歷史表來肯定節點是否缺乏心跳,所以若是小於ping所要求的,則mysql-monitor_history的值會自動調整爲如下值:
(mysql-monitor_ping_max_failures + 1 ) * mysql-monitor_ping_timeout

4、監控模塊的主線程[Main Threads]

監控模塊有幾個內部線程。目前有5個主線程:
1)Monitor ==>主線程,負責啓動和協調全部其餘線程;
2)monitor_connect_thread ==>鏈接檢查的主線程和調度程序;
3)monitor_ping_thread ==>ping檢查的主線程和調度程序;
4)monitor_read_only_thread ==>只讀檢查的主線程和調度程序;
5)monitor_replication_lag_thread ==>複製延遲檢查的主線程和調度程序;

在v1.2.0及以上版本中,處以上各線程的檢測外,Monitor線程也負責執行這些檢查。

5、監控模塊的線程池[Thread Pool]

在版本v1.2.0中因爲SSL在實現上的一些限制致使了版本的實現也不可避免的具備了限制:使用SSL時,connect()是阻塞調用的,
這將致使上面4個monitor_*_thread線程在執行鏈接階段時被柱塞。在版本v1.2.1嘗試使用新的實現方式來克服此限制。
目前:
1)Monitor會初始化一個 workers 的線程池並建立一個隊列;
2)monitor_connect_thread, monitor_ping_thread, monitor_read_only_thread 和 monitor_replication_lag_thread 它們生成任務並使用隊列將任務發送給workers;
3)workers 處理任務並執行須要的操做;
4)若是Monitor檢測到隊列增加太快,則會建立新的臨時 worker 線程。

6、鏈接清理[Connection purging]

Monitor實現了維護本身的鏈接池。超過 3 * mysql-monitor_ping_interval 毫秒的活動鏈接將自動被清除。

7、wait_timeout

爲防止後端自行終止鏈接,Monitor模塊自動配置了 wait_timeout = mysql-monitor_ping_interval * 10

完畢!

相關文章
相關標籤/搜索