MySQL 主從復制是一種允許從一個MySQL數據庫服務器上復制數據到另一個(稱為從服務器)的機制。從服務器可以是原始(主)服務器的副本,也可以是只讀的、用于查詢的服務器。在分布式系統中,MySQL 主從復制可以幫助應用程序平衡讀和寫負載,提高系統性能和可靠性。
在一個典型的主從分布系統中,主服務器用于更新,從服務器用于查詢。管理員在主服務器上執行寫操作(如更新、插入或刪除),然后MySQL系統將這些更改記錄到二進制日志(binary log)文件中。從服務器連接到主服務器,并讀取這些日志文件,執行與主服務器同步的操作。這些操作可以是對數據庫的查詢或寫操作,也可以是對其它數據源的操作。
示例代碼 # 在主服務器上設置二進制日志文件名和位置 vi /etc/mysql/my.cnf log-bin=mysql-bin server-id=1 # 在從服務器上設置二進制日志文件名和位置和從屬關系 vi /etc/mysql/my.cnf log-bin=mysql-bin server-id=2 relay-log=mysql-relay-bin relay-log-index=mysql-relay-bin.index replicate-ignore-db=mysql replicate-do-db=mydb master-host=master_server_IP master-user=slave_user master-password=slave_password master-port= master_server_port # 重啟MySQL服務 service mysql restart
MySQL 主從分布可以有多個從服務器連接到同一個主服務器。默認情況下,主服務器將所有更改記錄到二進制文件中,并等待從服務器連接后傳遞它們。從服務器可以通過設置過濾選項來選擇要過濾的事件。
總之,MySQL 主從復制是一個強大的機制,用于在不同的服務器之間同步數據,提高系統的性能和可靠性。通過在主服務器上記錄二進制日志,然后在從服務器上讀取和執行它們,可以使應用程序能夠平衡讀和寫負載,并且更輕松地實現高可用性和故障轉移。
上一篇mysql 主從 宕機
下一篇mysql 主從同步失敗