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

mysql 5.6.14主從復(fù)制(也稱mysql AB復(fù)制)環(huán)境配置方法

 更新時(shí)間:2016年04月17日 13:09:36   投稿:mdxy-dxy  
這篇文章主要介紹了mysql 5.6.14主從復(fù)制(也稱mysql AB復(fù)制)環(huán)境配置方法,需要的朋友可以參考下

一、mysql主(稱master)從(稱slave)復(fù)制的原理:

      (1).master將數(shù)據(jù)改變記錄到二進(jìn)制日志(binary log)中,也即是配置文件log-bin指定的文件(這些記錄叫做二進(jìn)制日志事件,binary log events)
      (2).slave將master的binary log events拷貝到它的中繼日志(relay log)
      (3).slave重做中繼日志中的事件,將改變反映它自己的數(shù)據(jù)(數(shù)據(jù)重演)

附簡要原理圖:

二、mysql主從復(fù)制支持的類型:

    (1).基于語句的復(fù)制:在主服務(wù)器上執(zhí)行的SQL語句,在從服務(wù)器上執(zhí)行同樣的語句.MySQL默認(rèn)采用基于語句的復(fù)制,效率比較高

word-spacing: 0px">   (2).基于行的復(fù)制:把改變的內(nèi)容直接復(fù)制過去,而不關(guān)心到底改變?cè)搩?nèi)容是由哪條語句引發(fā)的 . 從mysql5.0開始支持
word-spacing: 0px">   (3).混合類型的復(fù)制: 默認(rèn)采用基于語句的復(fù)制,一旦發(fā)現(xiàn)基于語句的無法精確的復(fù)制時(shí),就會(huì)采用基于行的復(fù)制.

三、主從配置需要注意的地方:

   (1).主DB server和從DB server數(shù)據(jù)庫的版本一致
   (2).主DB server和從DB server數(shù)據(jù)庫數(shù)據(jù)一致[ 這里就會(huì)可以把主的備份在從上還原,也可以直接將主的數(shù)據(jù)目錄拷貝到從的相應(yīng)數(shù)據(jù)目錄]
   (3).主DB server開啟二進(jìn)制日志,主DB server和從DB server的server_id都必須唯一

四、主從配置的簡要步驟:

附簡要示意圖:

1.主DB SERVER上的配置

   (1).安裝數(shù)據(jù)庫
   (2).修改數(shù)據(jù)庫配置文件,指明server_id,開啟二進(jìn)制日志(log-bin)
   (3).啟動(dòng)數(shù)據(jù)庫,查看當(dāng)前是哪個(gè)日志,position號(hào)是多少
   (4).登陸數(shù)據(jù)庫,授權(quán)用戶[ip地址為從機(jī)IP地址,如果是雙向主從,這里的還需要授權(quán)本機(jī)的IP地址(此時(shí)自己的IP地址就是從IP地址)]
   (5).備份數(shù)據(jù)庫[記得加鎖和解鎖]
   (6).傳送備份到從DB server上
   (7).啟動(dòng)數(shù)據(jù)庫

以下步驟,為單向主從搭建成功,想搭建雙向主從需要的步驟:

   (1).登陸數(shù)據(jù)庫,指定主DB server的地址,用戶,密碼等信息[此步僅雙向主從時(shí),需要]

   (2).開啟同步,查看狀態(tài)

2.從DB SERVER上的配置

  (1).安裝數(shù)據(jù)庫
  (2).修改數(shù)據(jù)庫配置文件,指明server_id[如果是搭建雙向主從的話,也要開啟二進(jìn)制日志(log-bin)]
  (3).啟動(dòng)數(shù)據(jù)庫,還原備份
  (4).查看當(dāng)前是哪個(gè)日志,position號(hào)是多少[單向主從此步不需要,雙向主從需要]
  (5).指定主DB server的地址,用戶,密碼等信息
  (6).開啟同步,查看狀態(tài)

五、單向主從環(huán)境[也稱 mysql A/B復(fù)制]的搭建案例:

1.主DB server和從DB server都安裝相應(yīng)版本的數(shù)據(jù)庫,我的兩臺(tái)DB server都已經(jīng)安裝好(5.6.14版本),都會(huì)是雙實(shí)例,這里就不演示安裝,可以參考mysql源碼編譯安裝和mysql多實(shí)例配置兩篇文章
注:兩臺(tái)機(jī)器的的selinux都是disable(永久關(guān)閉selinux,請(qǐng)修改/etc/selinux/config,將SELINUX改為disabled),防火墻可以選擇關(guān)閉,開啟的話也行[不行的話,添加防火墻策略]
2.修改主DB server的配置文件(/etc/my.cnf),開啟日志功能,設(shè)置server_id值,保證唯一[client102為主DB server]

[root@client102 scripts]# vim /etc/my.cnf 
# 修改配置文件里,下面兩個(gè)參數(shù): 
# 設(shè)置server_id,一般建議設(shè)置為IP,或者再加一些數(shù)字 
server_id =102
# 開啟二進(jìn)制日志功能,可以隨便取,最好有含義 
log-bin=mysql3306-bin

3.啟動(dòng)數(shù)據(jù)庫服務(wù)器,并登陸數(shù)據(jù)庫,授予相應(yīng)的用戶用于同步

# 我這里是多實(shí)例mysql,所以啟動(dòng)是這樣的,如果大家是單實(shí)例的,就直接啟動(dòng)就可以[/etc/init.d/mysqld start] 
[root@client102 scripts]# mysqld_multi start 3306 
# 登陸mysql 服務(wù)器 
[root@client102 scripts]# mysql -uroot -S /usr/local/mysql/mysqld3306.sock -p 
# 授予用戶權(quán)限用于主從同步 
mysql> grant replication slave on *.* to 'kongzhong'@'192.168.1.100' identified by 'kongzhong'; 
Query OK, 0 rows affected (0.00 sec) 
# 刷新授權(quán)表信息 
mysql> flush privileges; 
Query OK, 0 rows affected (0.00 sec) 
# 查看position 號(hào),記下position 號(hào)(很重要,從機(jī)上需要這個(gè)position號(hào)和現(xiàn)在的日志文件,我這里是414和mysql3306-bin.000001) 
mysql> show master status; 
+----------------------+----------+--------------+------------------+-------------------+
| File         | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | 
+----------------------+----------+--------------+------------------+-------------------+
| mysql3306-bin.000001 |   414 |       |         |          | 
+----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

4.為保證主DB server和從DB server的數(shù)據(jù)一致,這里采用主備份,從還原來實(shí)現(xiàn)初始數(shù)據(jù)一致

復(fù)制代碼 代碼如下:

# 臨時(shí)鎖表
mysql> flush tables with read lock;
# 我這里實(shí)行的全庫備份,在實(shí)際中,我們可能只同步某一個(gè)庫,可以只備份一個(gè)庫
# 新開一個(gè)終端,執(zhí)行如下操作
[root@client102 data]# mysqldump  -p3306 -uroot -p  -S /usr/local/mysql/mysqld3306.sock  --all-databases > /tmp/mysql.sql
# 解鎖
mysql> unlock tables;
# 將備份的數(shù)據(jù)傳送到從機(jī)上,用于恢復(fù)
 [root@client102 data]# scp  /tmp/mysql.sql  root@192.168.1.100:/tmp

5.從DB server配置文件只需修改一項(xiàng),其余用命令行做

復(fù)制代碼 代碼如下:

[root@client100 ~]# vim /etc/my.cnf
# 設(shè)置server_id,一般建議設(shè)置為IP,或者再加一些數(shù)字
server_id =100

6.啟動(dòng)數(shù)據(jù)庫,還原備份數(shù)據(jù)

復(fù)制代碼 代碼如下:

# 啟動(dòng)數(shù)據(jù)庫
[root@client100 ~]# mysqld_multi start 3306
# 還原主DB server備份的數(shù)據(jù)
[root@client100 ~]# mysql -uroot -S /usr/local/mysql/mysqld3306.sock -p < /tmp/mysql.sql

7.登陸數(shù)據(jù)庫,添加相關(guān)參數(shù)(主DBserver的ip/端口/同步用戶/密碼/position號(hào)/讀取哪個(gè)日志文件)

復(fù)制代碼 代碼如下:

[root@client100 ~]# mysql -uroot -S /usr/local/mysql/mysqld3306.sock -p
mysql> change master to
    -> master_host='192.168.1.102',
    -> master_user='kongzhong',
    -> master_password='kongzhong',
    -> master_port=3306,
    -> master_log_file='mysql3306-bin.000001',
    -> master_log_pos=414;
#/*  下面是一部分注解:
#/*  指定主DB server的IP地址
master_host='192.168.1.102'
#/*  指定用于同步的用戶[這個(gè)就是我們?cè)谥鱀B server授權(quán)的用戶]
master_user='kongzhong'
#/* 指定用于同步的用戶的密碼
master_password='kongzhong'
#/* 指定主DB server的端口[下面一個(gè)例子,可以重點(diǎn)看這個(gè)]
master_port=3306
#/*  指定從DB server 從哪個(gè)日志文件開始讀[在主DB server上使用show master status查看到日志]
master_log_file='mysql3306-bin.000001'
#/*  指定 從哪個(gè)POSITION號(hào)開始讀
master_log_pos=414
# 開啟主從同步
mysql> start slave;
# 查看主從同步狀態(tài)
mysql> show slave status\G;
# 主要看以下兩個(gè)參數(shù):[這兩個(gè)參數(shù)如果是yes就表示主從同步正常]
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

8.下面大家就可以在主DB server上新建一個(gè)表,看是否能同步到從DB server上,我這里就不測試了

[注:千萬不要在從DB server手動(dòng)插入數(shù)據(jù),那樣數(shù)據(jù)就不一致,主從就會(huì)斷開,需要重新配置了]

如果有問題,可以嘗試關(guān)閉IPTABLES(/etc/init.d/iptables stop)和selinux(setenforce 0:臨時(shí)關(guān)閉selinux,永久關(guān)閉selinux,請(qǐng)修改/etc/selinux/config,將SELINUX改為disabled)

9.上面所搭建的是單向主從,也是用的比較多的,有人想了解雙向主從是如何搭建,其實(shí),就是主DB server和從DB sever都開啟日志功能,然后在主DB SERVER執(zhí)行授權(quán)用戶[這里授權(quán)的是自己作為從服務(wù)器,也就是這里的IP地址是主DB server的IP地址],然后再在主DB server上進(jìn)行chang master操作.有不理解的可以留言詢問.

相關(guān)文章

  • mysql中的utf8與utf8mb4存儲(chǔ)及區(qū)別

    mysql中的utf8與utf8mb4存儲(chǔ)及區(qū)別

    本文主要介紹了mysql中的utf8與utf8mb4存儲(chǔ)及區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • MySQL?8.0.28?安裝配置圖文教程

    MySQL?8.0.28?安裝配置圖文教程

    這篇文章主要為大家詳細(xì)介紹了MySQL?8.0.28?安裝配置圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • MySql中的IFNULL、NULLIF和ISNULL用法詳解

    MySql中的IFNULL、NULLIF和ISNULL用法詳解

    在做項(xiàng)目中發(fā)現(xiàn)MySql里的isnull和mssql里的有點(diǎn)不同。接下來小編通過本文給大家介紹MySql中的IFNULL、NULLIF和ISNULL用法詳解的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-09-09
  • MySQL 配置優(yōu)化(多個(gè)參數(shù))

    MySQL 配置優(yōu)化(多個(gè)參數(shù))

    安裝MySQL后,配置文件my.cnf在 /MySQL安裝目錄/share/mysql目錄中,該目錄中還包含多個(gè)配置文件可供參考,有my-large.cnf ,my-huge.cnf, my-medium.cnf,my-small.cnf,分別對(duì)應(yīng)大中小型數(shù)據(jù)庫應(yīng)用的配置。win環(huán)境下即存在于MySQL安裝目錄中的.ini文件
    2016-05-05
  • MySQL數(shù)據(jù)同步Elasticsearch的4種方案

    MySQL數(shù)據(jù)同步Elasticsearch的4種方案

    本文主要介紹了MySQL數(shù)據(jù)同步Elasticsearch的4種方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • 解析MySQL中DELETE語句中別名的使用

    解析MySQL中DELETE語句中別名的使用

    這篇文章主要為大家介紹了MySQL中DELETE語句中別名的使用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • MySQL的23個(gè)需要注意的地方

    MySQL的23個(gè)需要注意的地方

    本文將為大家介紹的是MySQL數(shù)據(jù)庫的23個(gè)特別注意事項(xiàng),希望各位DBA能從中得到一些啟發(fā)。
    2010-08-08
  • 關(guān)于數(shù)據(jù)庫連接池Druid使用說明

    關(guān)于數(shù)據(jù)庫連接池Druid使用說明

    這篇文章主要介紹了關(guān)于數(shù)據(jù)庫連接池Druid使用說明,涉及Druid 參數(shù)和運(yùn)行原理等等相關(guān)內(nèi)容,小編覺得挺不錯(cuò)的,在這里給大家分享一下。
    2017-10-10
  • You have an error in your SQL syntax; check the manual that corresponds解決方法

    You have an error in your SQL&

    You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version
    2023-02-02
  • MySQL如何刪除表中的數(shù)據(jù)

    MySQL如何刪除表中的數(shù)據(jù)

    這篇文章主要介紹了MySQL如何刪除表中的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評(píng)論