欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ubuntu 16.04配置MySQL主從同步的配置方法

 更新時間:2018年03月30日 10:56:38   作者:默默的點(diǎn)滴  
這篇文章主要介紹了ubuntu 16.04配置MySQL主從同步的配置方法,需要的朋友可以參考下

準(zhǔn)備工作

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)一下實(shí)際保存的內(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)一下實(shí)際保存的內(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ù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • MySQL 5.7雙主同步部分表的實(shí)現(xiàn)過程詳解

    MySQL 5.7雙主同步部分表的實(shí)現(xiàn)過程詳解

    這篇文章主要給大家介紹了關(guān)于MySQL 5.7雙主同步部分表實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • MySQL報錯Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre

    MySQL報錯Expression #1 of SELECT list 

    這篇文章主要介紹了MySQL報錯Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • MySQL筆記之視圖的使用詳解

    MySQL筆記之視圖的使用詳解

    使用視圖的大部分情況是為了保障數(shù)據(jù)安全性,提高查詢效率
    2013-05-05
  • mysql中如何查看表空間

    mysql中如何查看表空間

    這篇文章主要介紹了mysql中如何查看表空間問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • MySQL多實(shí)例的配置應(yīng)用實(shí)例場景

    MySQL多實(shí)例的配置應(yīng)用實(shí)例場景

    在一臺服務(wù)器上,運(yùn)行多個數(shù)據(jù)庫服務(wù),這些服務(wù)進(jìn)程通過不同的socket監(jiān)聽不同的服務(wù)端口來提供各自的服務(wù),這篇文章主要介紹了MySQL多實(shí)例的配置場景分析,需要的朋友可以參考下
    2021-12-12
  • docker 部署mysql詳細(xì)過程(docker部署常見應(yīng)用)

    docker 部署mysql詳細(xì)過程(docker部署常見應(yīng)用)

    這篇文章主要介紹了docker 部署mysql之docker部署常見應(yīng)用,本文以docker部署mysql5.7.26為例,通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • MySQL存儲過程的傳參和流程控制示例講解

    MySQL存儲過程的傳參和流程控制示例講解

    這篇文章主要介紹了MySQL存儲過程的傳參和流程控制示例講解,?repeat和Loop區(qū)別是repeat有自己退出循環(huán)的語句until,Loop使用的是if判斷語句,本文結(jié)合示例代碼詳細(xì)講解,需要的朋友可以參考下
    2023-02-02
  • Python?Matplotlib繪圖基礎(chǔ)詳細(xì)教程

    Python?Matplotlib繪圖基礎(chǔ)詳細(xì)教程

    matplotlib是python中用于繪制各種圖像的模塊,功能十分強(qiáng)大,通常與pandas模塊搭配使用,可以生成各種樣視的圖片,用于數(shù)據(jù)的分析和展示,下面這篇文章主要給大家介紹了關(guān)于Python?Matplotlib繪圖基礎(chǔ)的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • MySQL索引操作命令詳解

    MySQL索引操作命令詳解

    這篇文章主要介紹了MySQL索引操作命令詳解,需要的朋友可以參考下
    2017-01-01
  • 有關(guān)mysql中sql的執(zhí)行順序的小問題

    有關(guān)mysql中sql的執(zhí)行順序的小問題

    在MySQL中我們可能會遇到一些關(guān)于執(zhí)行順序的問題,下面小編就來帶大家了解一下原因以及如何解決
    2019-05-05

最新評論