準(zhǔn)備工作
成都創(chuàng)新互聯(lián)公司為企業(yè)級客戶提高一站式互聯(lián)網(wǎng)+設(shè)計服務(wù),主要包括成都網(wǎng)站建設(shè)、成都做網(wǎng)站、成都App定制開發(fā)、重慶小程序開發(fā)公司、宣傳片制作、LOGO設(shè)計等,幫助客戶快速提升營銷能力和企業(yè)形象,創(chuàng)新互聯(lián)各部門都有經(jīng)驗豐富的經(jīng)驗,可以確保每一個作品的質(zhì)量和創(chuàng)作周期,同時每年都有很多新員工加入,為我們帶來大量新的創(chuàng)意。
1.主從數(shù)據(jù)庫版本最好一致
2.主從數(shù)據(jù)庫內(nèi)數(shù)據(jù)保持一致
主數(shù)據(jù)庫:121.199.27.227 /ubuntu 16.04 MySQL 5.7.21 ( 阿里云 )
從數(shù)據(jù)庫:182.254.149.39 /ubuntu 16.04 MySQL 5.7.21 ( 騰訊云 )
防火墻配置
配置主服務(wù)器只允許特定 IP 訪問數(shù)據(jù)庫的端口,避免不必要的攻擊。
主庫防火墻配置
# iptables -A INPUT -p tcp -s slave_ip --dport 3306 -j ACCEPT #刪除可能已經(jīng)存在的配置,避免出現(xiàn)多條重復(fù)記錄 $ sudo iptables -D INPUT -p tcp -s 182.254.149.39 --dport 3306 -j ACCEPT $ sudo iptables -D INPUT -p tcp -s 127.0.0.1 --dport 3306 -j ACCEPT $ sudo iptables -D INPUT -p tcp --dport 3306 -j DROP $ sudo iptables -D INPUT -p udp --dport 3306 -j DROP $ sudo iptables -D INPUT -p sctp --dport 3306 -j DROP #增加配置,只允許特定地址訪問數(shù)據(jù)庫端口 $ sudo iptables -A INPUT -p tcp -s 182.254.149.39 --dport 3306 -j ACCEPT $ sudo iptables -A INPUT -p tcp -s 127.0.0.1 --dport 3306 -j ACCEPT $ sudo iptables -A INPUT -p tcp --dport 3306 -j DROP $ sudo iptables -A INPUT -p udp --dport 3306 -j DROP $ sudo iptables -A INPUT -p sctp --dport 3306 -j DROP $ sudo iptables -L -n #保存配置 $ sudo apt-get install iptables-persistent $ sudo netfilter-persistent save #配置被保存到/etc/iptables/rules.v4 /etc/iptables/rules.v6這兩個文件下面, #最好確認(rèn)一下實際保存的內(nèi)容,尤其是安裝了denyhosts等其他安全軟件的情況下, #可能會記錄了多余的規(guī)則,需要手工刪除 從庫防火墻配置 # iptables -A OUTPUT -p tcp -d master_ip --dport 3306 -j ACCEPT #刪除可能已經(jīng)存在的配置,避免出現(xiàn)多條重復(fù)記錄 $ sudo iptables -D OUTPUT -p tcp -d 121.199.27.227 --dport 3306 -j ACCEPT #增加配置 $ sudo iptables -A OUTPUT -p tcp -d 121.199.27.227 --dport 3306 -j ACCEPT $ sudo iptables -L -n #保存配置 $ sudo apt-get install iptables-persistent $ sudo netfilter-persistent save #配置被保存到/etc/iptables/rules.v4 /etc/iptables/rules.v6這兩個文件下面, #最好確認(rèn)一下實際保存的內(nèi)容,尤其是安裝了denyhosts等其他安全軟件的情況下, #可能會記錄了多余的規(guī)則,需要手工刪除
主數(shù)據(jù)庫master配置
1.修改mysql配置
$ sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
在[mysqld]部分進(jìn)行如下修改:
[mysqld] log-bin = /var/log/mysql/mysql-bin.log #開啟二進(jìn)制日志,默認(rèn)是注釋掉的,我們?nèi)サ糇⑨?server-id = 1 #設(shè)置server-id bind-address = 0.0.0.0 #默認(rèn)是127.0.0.1,此處我們設(shè)置為任意地址,放開遠(yuǎn)程訪問,這么操作之前一定要確保防火墻配置正確,否則會產(chǎn)生安全風(fēng)險
2.重啟mysql,創(chuàng)建用于同步的用戶賬號
創(chuàng)建用戶并授權(quán):用戶:repl 密碼:slavepass
$ sudo service mysql restart $ mysql -u root -p -e "CREATE USER 'repl'@'182.254.149.39' IDENTIFIED BY 'slavepass';" #創(chuàng)建用戶 $ mysql -u root -p -e "GRANT REPLICATION SLAVE ON *.* TO 'repl'@'182.254.149.39';" #分配權(quán)限 $ mysql -u root -p -e "flush privileges;" #刷新權(quán)限
3.查看master狀態(tài),記錄二進(jìn)制文件名(mysql-bin.000001)和位置(333802):
$ mysql -u root -p -e "SHOW MASTER STATUS;" Enter password: +------------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +------------------+----------+--------------+------------------+-------------------+ | mysql-bin.000001 | 333802 | | | | +------------------+----------+--------------+------------------+-------------------+
4.主庫備份,為從庫的第一次數(shù)據(jù)同步準(zhǔn)備數(shù)據(jù)
使用如下腳本產(chǎn)生數(shù)據(jù)庫備份文件
#此處以備份wordpress數(shù)據(jù)庫為例子 datadump=`which mysqldump` mysqluser="root" userpass="password" wordpressdb="wordpress" backupwordpress_sql=$wordpressdb.`date +%Y%m%d`.sql if $datadump -u $mysqluser --password=$userpass -h localhost --opt $wordpressdb > $backupwordpress_sql 2>&1 then echo " backup $wordpressdb success" else echo " backup $wordpressdb error" exit 1 fi #檢驗文件尾部是否存在 “-- Dump completed on”,如果存在不存在,則說明備份出錯了。 if [ 0 -eq "$(sed '/^$/!h;$!d;g' $backupwordpress_sql | grep -c "Dump completed on")" ]; then echo " backup $wordpressdb error" exit 1 else echo " backup $wordpressdb success" fi
執(zhí)行腳本,確保最后輸出備份成功
$ cd ~ $ sudo bash backup_wordpress.sh
從服務(wù)器slave配置
1.修改mysql配置
$ sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
修改server-id,每個數(shù)據(jù)庫的server-id要求是唯一的,不能相互沖突
[mysqld] server-id = 2 #設(shè)置server-id,必須唯一 log_bin = /var/log/mysql/mysql-bin.log #日志也最好打開
2.首次還原數(shù)據(jù)庫:
$ sudo service mysql restart $ scp -P 22 -r root@121.199.27.227:~/wordpress.*.sql ./ #刪除可能存在的一行警告信息,這行警告信息可能導(dǎo)致我們無法恢復(fù)數(shù)據(jù) $ sed -i "/^mysqldump: \[Warning\] Using a password on the command line interface can be insecure\./d" wordpress.*.sql $ mysql -u root -p -e "drop database wordpress;" $ mysql -u root -p -e "create database wordpress;" $ mysql -u root -p wordpress < wordpress.*.sql
3.重啟mysql,打開mysql會話,執(zhí)行同步SQL語句(需要主服務(wù)器主機(jī)名,登陸憑據(jù),二進(jìn)制文件的名稱和位置):
$ mysql -u root -p -e "CHANGE MASTER TO MASTER_HOST='121.199.27.227', MASTER_USER='repl', MASTER_PASSWORD='slavepass', MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=333802;"
4.啟動slave同步進(jìn)程:
$ mysql -u root -p -e "start slave;"
5.查看slave狀態(tài):
$ mysql -u root -p -e "show slave status\G;" Enter password: *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 121.199.27.227 Master_User: repl Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin.000001 Read_Master_Log_Pos: 9448236 Relay_Log_File: VM-114-251-ubuntu-relay-bin.000002 Relay_Log_Pos: 17780 Relay_Master_Log_File: mysql-bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: No Replicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: ...
當(dāng)Slave_IO_Running和Slave_SQL_Running都為YES的時候就表示主從同步設(shè)置成功了。接下來就可以進(jìn)行一些驗證了,比如在主master數(shù)據(jù)庫的test數(shù)據(jù)庫的一張表中插入一條數(shù)據(jù),在slave的test庫的相同數(shù)據(jù)表中查看是否有新增的數(shù)據(jù)即可驗證主從復(fù)制功能是否有效,還可以關(guān)閉slave(mysql>stop slave;),然后再修改master,看slave是否也相應(yīng)修改(停止slave后,master的修改不會同步到slave),就可以完成主從復(fù)制功能的驗證了。
還可以用到的其他相關(guān)參數(shù):
master開啟二進(jìn)制日志后默認(rèn)記錄所有庫所有表的操作,可以通過配置來指定只記錄指定的數(shù)據(jù)庫甚至指定的表的操作,具體在mysql配置文件的[mysqld]可添加修改如下選項:
# 不同步哪些數(shù)據(jù)庫 binlog-ignore-db = mysql binlog-ignore-db = test binlog-ignore-db = information_schema # 只同步哪些數(shù)據(jù)庫,除此之外,其他不同步 binlog-do-db = game
如之前查看master狀態(tài)時就可以看到只記錄了test庫,忽略了manual和mysql庫。
總結(jié)
以上所述是小編給大家介紹的ubuntu 16.04配置MySQL主從同步的配置方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!