實現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的時候就表示主從同步設置成功了。