主從複製

實現MySQL主從複製需要進行的配置:


主服務器:

開啓二進制日誌

配置唯一的server-id

獲得master二進制日誌文件名及位置

創建一個用於slave和master通信的用戶賬號

從服務器:

配置唯一的server-id

使用master分配的用戶賬號讀取master二進制日誌

啓用slave服務

具體實現過程如下:


一、準備工作:


1.主從數據庫版本最好一致


2.主從數據庫內數據保持一致


主數據庫:182.92.172.80 /linux


從數據庫:123.57.44.85 /linux


二、主數據庫master修改:


1.修改mysql配置


找到主數據庫的配置文件my.cnf(或者my.ini),我的在/etc/mysql/my.cnf,在[mysqld]部分插入如下兩行:


[mysqld]

log-bin=mysql-bin #開啓二進制日誌

server-id=1 #設置server-id

2.重啓mysql,創建用於同步的用戶賬號


打開mysql會話shell>mysql -hlocalhost -uname -ppassword


創建用戶並授權:用戶:rel1密碼:slavepass


mysql> CREATE USER 'repl'@'123.57.44.85' IDENTIFIED BY 'slavepass';#創建用戶

mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'123.57.44.85';#分配權限

mysql>flush privileges;   #刷新權限

3.查看master狀態,記錄二進制文件名(mysql-bin.000003)和位置(73):


複製代碼

mysql > SHOW MASTER STATUS;

+------------------+----------+--------------+------------------+

| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |

+------------------+----------+--------------+------------------+

| mysql-bin.000003 | 73       | test         | manual,mysql     |

+------------------+----------+--------------+------------------+

複製代碼

二、從服務器slave修改:


1.修改mysql配置


同樣找到my.cnf配置文件,添加server-id


[mysqld]

server-id=2 #設置server-id,必須唯一

2.重啓mysql,打開mysql會話,執行同步SQL語句(需要主服務器主機名,登陸憑據,二進制文件的名稱和位置):


mysql> CHANGE MASTER TO

    ->     MASTER_HOST='182.92.172.80',

    ->     MASTER_USER='rep1',

    ->     MASTER_PASSWORD='slavepass',

    ->     MASTER_LOG_FILE='mysql-bin.000003',

    ->     MASTER_LOG_POS=73;

3.啓動slave同步進程:


mysql>start slave;

4.查看slave狀態:


複製代碼

mysql> show slave status\G;

*************************** 1. row ***************************

               Slave_IO_State: Waiting for master to send event

                  Master_Host: 182.92.172.80

                  Master_User: rep1

                  Master_Port: 3306

                Connect_Retry: 60

              Master_Log_File: mysql-bin.000013

          Read_Master_Log_Pos: 11662

               Relay_Log_File: mysqld-relay-bin.000022

                Relay_Log_Pos: 11765

        Relay_Master_Log_File: mysql-bin.000013

             Slave_IO_Running: Yes

            Slave_SQL_Running: Yes

              Replicate_Do_DB: 

          Replicate_Ignore_DB: 

        ...

複製代碼

當Slave_IO_Running和Slave_SQL_Running都爲YES的時候就表示主從同步設置成功了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章