為什麼要進行mysql主從配置,它的優勢提現在哪些面向?本文主要和大家分享mysql主從配置實例詳解,希望能幫助大家。
1:實作伺服器負載平衡
在主伺服器上只實作資料的更新操作,而不關心資料的查詢。查詢請求可以轉發到多個從伺服器。將資料更新與查詢分別放在不同的伺服器 上進行,即可以提高資料的安全性,同時也縮短應用程式的回應時間、提高系統的效能。
2:透過複製實現資料的異地備份
任何時候,資料備份都是相當重要的一個環節,而mysql主從配置,很好的實現了異地備份,完美的解決了這個問題。
3:提高資料庫系統的可用性
資料庫複製功能實現了主伺服器與從伺服器之間資料的同步,增加了資料庫系統的可用性。當主伺服器出現問題時,資料庫管理員可以馬上讓從伺服器作為主伺服器,用來資料的更新與查詢服務。
從伺服器(slave)是怎麼複製主伺服器(master)上的資料?
1:當master中資料改變時,它會將改變記錄到二進位日誌(binary log)。
2:slave將master的日誌拷貝到自己的中繼日誌(relay log)。
3:slave根據日誌記錄來更新資料。
設定主從mysql
1:設定master伺服器
(1):在Master MySQL上建立一個使用者'link',並授權其他Slave伺服器可以透過link用戶遠端存取Master,讀取二進位日誌,實現資料同步。
mysql> create user link;
mysql> GRANT REPLICATION SLAVE ON *.* TO 'link'@'%' IDENTIFIED BY 'mysql';
(2):修改mysql設定檔my.ini(windows)/ my.cnf(linux)
如果是linux環境,修改/etc/my.cnf文件,如果是windows環境,找到mysql安裝目錄下的my.ini檔案。在[mysqld]下面新增以下幾行語句:
server-id=1 //给数据库服务的唯一标识,必须唯一 log-bin=master-bin //开启二进制日志 log-bin-index=master-bin.index
(3)重啟mysql,查看狀態,輸出如下
mysql> SHOW MASTER STATUS; +-------------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +-------------------+----------+--------------+------------------+-------------------+ | master-bin.000001 | 350 | | | | +-------------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec)
2:設定slave伺服器
(1)修改mysql設定文件,加入下面幾行語句:
server-id=2 relay-log-index=slave-relay-bin.index relay-log=slave-relay-bin //配置中继日志 log_slave_updates = 1 //表示slave将复制事件写进自己的二进制日志 #replicate-do-table=bison.user //库名.表名 用来指定只对数据库中的某张表做同步
(2)重新啟動mysql,連接master
mysql重新啟動完成後,登入mysql,使用CHANGE MASTER TO語句連接master
mysql> CHANGE MASTER TO MASTER_HOST='192.168.1.123',//主服务器ip -> MASTER_USER='link', -> MASTER_PASSWORD='mysql', -> MASTER_LOG_FILE='mysql-bin.000001',//master服务器日志文件,主服务器mysql使用SHOW MASTER STATUS语句 -> MASTER_LOG_POS=0;//日志的开始位置
(3)查看是否配置正確
mysql> SHOW SLAVE STATUS\G
部分显示如下: *************************** 1. row *************************** Slave_IO_State: Master_Host: server1 Master_User: repl Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin.000001 Read_Master_Log_Pos: 4 Relay_Log_File: mysql-relay-bin.000001 Relay_Log_Pos: 4 Relay_Master_Log_File: mysql-bin.000001 <span style="color:#ff0000;"><strong> Slave_IO_Running: No Slave_SQL_Running: No</strong></span>
(4)開啟slave
mysql> start slave;
#檢視設定:
mysql> SHOW SLAVE STATUS\G
部分显示如下:主要看Slave_IO_Running和Slave_SQL_Running
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.1.234
Master_User: link
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: master-bin.000001
Read_Master_Log_Pos: 350
Relay_Log_File: slave-relay-bin.000002
Relay_Log_Pos: 548
Relay_Master_Log_File: master-bin.000001
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
ok了,在主伺服器建立資料庫試試看。
相關推薦:
#以上是mysql主從配置實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!