首頁 >後端開發 >php教程 >mysql主從配置實例詳解

mysql主從配置實例詳解

小云云
小云云原創
2018-03-21 09:11:551510瀏覽

為什麼要進行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,讀取二進位日誌,實現資料同步。

  1. mysql> create user link;  

  2. 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]下面新增以下幾行語句:

  1. 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設定文件,加入下面幾行語句:

  1. 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)查看是否配置正確

  1. 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>
  1. (4)開啟slave

  2. 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伺服器中主從設定介紹

Mysql系列(十五)mysql主從設定

mysql資料庫主從配置詳解

#

以上是mysql主從配置實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn