MySQL主從數據庫是一種常見的架構模式,能夠提高性能和可靠性。主數據庫負責寫操作,從數據庫負責讀操作,讀寫分離可以優化查詢性能,而主從同步可以提高系統的可靠性和靈活性。
在MySQL主從復制架構中,主數據庫是主節點,從數據庫是從節點。主節點接收寫操作并將變更記錄到二進制日志 (binary log) 中。從節點定期連接到主節點,下載二進制日志并將其執行,使得從節點也能夠保持和主節點一致的數據狀態。
MySQL主從同步有兩種方式:基于語句的復制 (statement-based replication) 和基于行的復制 (row-based replication)。基于語句的復制是通過解析和重放SQL語句來同步數據,而基于行的復制是通過傳輸二進制數據來同步數據。前者適用于大多數情況下,后者適用于一些特殊情況,例如需要復制大型二進制數據對象 (BLOB) 的情況。
# 以下是創建主從復制時的基本步驟 (以基于語句的復制為例) # 在主節點上創建一個用于復制的賬戶,并授予 REPLICATION SLAVE 權限 CREATE USER 'replication'@'%' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%'; # 在主節點上開啟二進制日志并設置唯一標識 # 需要設置 server-id,可以是任何正整數 # 需要設置 log-bin,開啟二進制日志 # 需要設置 binlog-format,選擇基于語句或基于行,建議使用默認值 server-id = 1 log-bin = mysql-bin binlog-format = STATEMENT # 在主節點上執行 SHOW MASTER STATUS 命令來查看二進制日志的狀態 # 記錄 File 和 Position 的值,后續需要用到 SHOW MASTER STATUS; # 在從節點上執行 CHANGE MASTER TO 命令來連接主節點并開始同步 # 需要設置 master-host,主節點的 IP 或域名 # 需要設置 master-user 和 master-password,用于連接主節點的賬戶和密碼 # 需要設置 master-log-file 和 master-log-position,即主節點上記錄的 File 和 Position 的值 # 需要設置 master-connect-retry,用于連接不上主節點時的重試次數 # 其他參數可以按需設置,建議使用默認值 CHANGE MASTER TO MASTER_HOST='192.168.0.1', MASTER_USER='replication', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107; # 在從節點上執行 START SLAVE 命令來啟動同步 START SLAVE; # 在從節點上執行 SHOW SLAVE STATUS 命令來查看同步的狀態 # 如果 Slave_IO_Running 和 Slave_SQL_Running 等于 YES,說明同步正常進行 SHOW SLAVE STATUS;
以上是創建MySQL主從復制的基本步驟。在實際使用中,還需要注意一些細節,例如主從服務器的硬件配置和網絡環境的穩定性。同時,需要定期進行主從數據一致性的檢測和備份,以確保數據的完整性和可靠性。
下一篇mysql 主備原理