在MySQL數據庫中,主從同步是一種非常有用的功能,它可以大大提高數據的可靠性和可用性。在這種架構中,一個數據庫服務器作為主服務器來處理寫請求,而另外一個或多個服務器作為從服務器來接收主服務器所做的更改并同步它們的數據。因此,即使主服務器出現故障,從服務器也可以接管并繼續處理請求。下面我們來看一下如何進行MySQL主從配置。
1、在主服務器上打開binlog的日志功能 在主服務器上向my.cnf文件中添加以下代碼: log-bin=mysql-bin 下面的代碼可以配置MySQL寫入binlog時刪除一個表格的相關操作不會被記錄進binlog日志中,如果不加此項配置,則任何一個數據庫操作都會被記錄到binlog中: binlog-ignore-db=mysql 2、新建一個同步用戶 在主服務器上,用以下命令創建一個同步用戶,用戶名為repl,密碼為password: GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' IDENTIFIED BY 'password'; 注意要指定該用戶有' REPLICATION SLAVE '的權限,并且能夠被從服務器的任意ip地址訪問到。 3、重啟Mysql服務器并查看binlog文件名和位置 重啟mysql后,可以通過以下命令查看主服務器的binlog的文件名和對應位置: mysql>show master status; +------------------+----------+--------------+------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | +------------------+----------+--------------+------------------+ | mysql-bin.000001 | 107 | | | +------------------+----------+--------------+------------------+ 4、在從服務器上配置 在從服務器上向my.cnf文件中添加如下代碼,其中,SERVER_IP_ADDRESS是主服務器的IP地址,PORT是主服務器的MySQL端口號 server-id=2 relay-log=mysql-relay-bin relay-log-index=mysql-relay-bin.index replicate-ignore-db=information_schema replicate-do-db=testdb log_slave_updates=1 master-host=111.222.333.444 master-user=repl master-password=password master-port=PORT 注意從服務器的server-id必須不同于主服務器的server-id。 5、重啟從服務器并啟動同步 重啟從服務器后,在MySQL中連接到從服務器,并通過以下命令啟動同步,其中MASTER_LOG_FILE和MASTER_LOG_POS是之前在主服務器上看到的binlog的文件名和位置: mysql>CHANGE MASTER TO MASTER_HOST='SERVER_IP_ADDRESS',MASTER_USER='repl', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107; mysql>START SLAVE; 現在,從服務器就可以開始同步主服務器的數據了。
以上就是MySQL主從同步的配置流程,它可以大幅提高MySQL數據的可靠性和可用性,確保即使主服務器出現故障,從服務器也能夠立即接管服務,并保持數據的一致性。通過合理配置,MySQL主從同步可以幫助您構建更加健壯和可靠的數據架構。