這期內容當中小編將會給大家?guī)碛嘘P怎么理解MySQL Replication的復制線程,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
合山ssl適用于網站、小程序/APP、API接口等需要進行數據傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!
MySQL Replication由以下線程組成:
(1).binlog Dump線程
Binlog Dump線程運行在主服務器上,可以通過語句show processlist來查看該線程是否運行,它負責將主服務器上二進制日志文件中的內容發(fā)送給從服務器的I/O線程。Binlog Dump線程同時還會給每個將要傳輸的事件加鎖,一旦事件傳輸完畢鎖就會立即釋放。
(2).I/O線程
當從服務器端執(zhí)行start slave語句后,便會運行一個I/O線程。它將會與主服務器建立一個連接,同時會向主服務器發(fā)出更新請求,要求將主服務器上的二進制日志文件中更新過的事件發(fā)送給此進程。之后,I/O線程會將傳遞過來的更新復制到本地Relay Log的日志中,通過
語句show slave status來查看I/O線程的狀態(tài),Slave_IO_Running為此線程的狀態(tài)參數。
(3).SQL線程
SQL線程負責讀取Relay Log日志中的更新事件,并將這些事件挨個執(zhí)行,使從服務器上的數據庫得到更新,同樣SQL線程也要一個狀態(tài)參數Slave_SQL_Running,并與I/O線程提供的狀態(tài)參數一起,作為判斷復制進程運行的重要參數。
備注:
主服務器端的Binlog文件是實現復制功能的首要文件,需要注意的是,在啟動數據庫之前,需要先啟用二進制日志功能,需要將配置文件my.cnf中的參數log-bin前的注釋去掉,并設置名字,例如:
[mysqld]
log_bin=mysql-bin
從服務器端的Relay Log文件,在運行start slave命令后產生。Relay Log和Binlog具有相同的格式,兩個日志文件都可以通過mysqlbinlog工具來查看,不同之處在于SQL線程會自動刪除Relay Log文件中已經被執(zhí)行過的事件。
上述就是小編為大家分享的怎么理解MySQL Replication的復制線程了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。