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

MySQL主從復(fù)制原理解析與最佳實(shí)踐過(guò)程

 更新時(shí)間:2023年05月16日 09:14:51   作者:不愛(ài)編程的設(shè)計(jì)師  
這篇文章主要介紹了MySQL主從復(fù)制原理解析與最佳實(shí)踐過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

一、主從復(fù)制

1、復(fù)制的基本原理

主要涉及三個(gè)線程:binlog 線程、I/O 線程和 SQL 線程

  • binlog 線程 :負(fù)責(zé)將主服務(wù)器上的數(shù)據(jù)更改寫入二進(jìn)制日志(Binary log)中
  • I/O 線程 :負(fù)責(zé)在主服務(wù)器上讀取二進(jìn)制日志,并寫入從服務(wù)器的中繼日志(Relay log)
  • SQL 線程 :負(fù)責(zé)讀取中繼日志,解析出主服務(wù)器已經(jīng)執(zhí)行的數(shù)據(jù)更改并在從服務(wù)器中執(zhí)行

2、復(fù)制的基本原則

  • 每個(gè)master可以有多個(gè)slave
  • 每個(gè)slave只有一個(gè)master
  • 每個(gè)slave只能有一個(gè)唯一的服務(wù)器ID

二、最佳實(shí)踐

  • 本次實(shí)踐采用一主一從復(fù)制,一主為windows,一從為虛擬機(jī)Centos7,MySQL版本5.7保持一致

1、ping測(cè)試

  • 虛擬機(jī)采用NAT連接,物理機(jī)關(guān)閉防火墻
  • 雙方互相進(jìn)行ping測(cè)試,記錄主從各自服務(wù)器的IP地址

2、主服務(wù)器配置

  • 修改my.ini文件,默認(rèn)在C:\ProgramData\MySQL\MySQL Server 5.7

主服務(wù)器唯一ID

[mysqld]
server-id=1

啟用二進(jìn)制文件

log-bin="mysqlbin"

關(guān)閉只讀

#可選
read-only=0

忽略備份

#可選
binlog-ignore-db=mysql

設(shè)置備份

#可選
binlog-do-db=test

3、從服務(wù)器配置

從服務(wù)器唯一ID

[mysqld]
server-id=2

啟用二進(jìn)制文件

log-bin="mysqlbin"

4、主服務(wù)器設(shè)置

  • CMD打開MySQL會(huì)話

創(chuàng)建用戶

#可選
CREATE USER 'test'@'從服務(wù)器IP' IDENTIFIED BY 'test';
#CREATE USER 'test'@'192.168.189.129' IDENTIFIED BY 'test';

賦予權(quán)限

grant replication slave on *.* to 'test'@'192.168.189.129' identified by 'test';

刷新權(quán)限

flush privileges;

查看master狀態(tài)

show master status\G;

記錄二進(jìn)制文件名和位置

+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000003 | 73       | test         | manual,mysql     |
+------------------+----------+--------------+------------------+

5、從服務(wù)器設(shè)置

  • CMD打開MySQL會(huì)話

執(zhí)行同步SQL

#主服務(wù)器IP、用戶名、密碼、二進(jìn)制文件名、位置
change master to master_host='192.168.189.1',
master_user='test',
master_password='test',
master_log_file='mysql-bin.000003',master_log_pos=73;

開啟slave

start slave;

查看slave狀態(tài)

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: 
  • 當(dāng)Slave_IO_Running和Slave_SQL_Running都為YES的時(shí)候就表示主從同步設(shè)置成功了。
  • 如果不成功,先關(guān)閉slave,重新進(jìn)行從服務(wù)器設(shè)置

6、主從測(cè)試

  • 在主服務(wù)器備份的數(shù)據(jù)庫(kù)(本次為test)中插入一條數(shù)據(jù),在從服務(wù)器中驗(yàn)證是否復(fù)制成功(成功)
  • 在主服務(wù)器中新建一個(gè)數(shù)據(jù)庫(kù),插入多條數(shù)據(jù),在從服務(wù)器中驗(yàn)證是否復(fù)制成功(備份指定數(shù)據(jù)庫(kù),復(fù)制失敗)
  • 關(guān)閉slave(mysql>stop slave;),然后再修改master,看slave是否也相應(yīng)修改(停止slave后,master的修改不會(huì)同步到slave),就可以完成主從復(fù)制功能的驗(yàn)證了

7、關(guān)閉slave

stop slave;

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • mysql 8.0.20 安裝配置詳細(xì)教程

    mysql 8.0.20 安裝配置詳細(xì)教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.20 安裝配置詳細(xì)教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • C#實(shí)現(xiàn)MySQL命令行備份和恢復(fù)

    C#實(shí)現(xiàn)MySQL命令行備份和恢復(fù)

    MySQL數(shù)據(jù)庫(kù)的備份有很多工具可以使用,今天介紹一下使用C#調(diào)用MYSQL的mysqldump命令完成MySQL數(shù)據(jù)庫(kù)的備份與恢復(fù)
    2018-03-03
  • MySQL數(shù)據(jù)庫(kù)操作常用命令小結(jié)

    MySQL數(shù)據(jù)庫(kù)操作常用命令小結(jié)

    這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)操作常用命令小結(jié),例如創(chuàng)建數(shù)據(jù)庫(kù)、使用數(shù)據(jù)庫(kù)、查看數(shù)據(jù)庫(kù)、數(shù)據(jù)庫(kù)編碼操作等命令講解,需要的朋友可以參考下
    2014-12-12
  • 解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題

    解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題

    這篇文章主要介紹了解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題,需要的朋友可以參考下
    2017-03-03
  • MySQL數(shù)據(jù)庫(kù)表的合并與分區(qū)實(shí)現(xiàn)介紹

    MySQL數(shù)據(jù)庫(kù)表的合并與分區(qū)實(shí)現(xiàn)介紹

    今天我們來(lái)聊聊處理大數(shù)據(jù)時(shí)Mysql的存儲(chǔ)優(yōu)化。當(dāng)數(shù)據(jù)達(dá)到一定量時(shí),一般的存儲(chǔ)方式就無(wú)法解決高并發(fā)問(wèn)題了。最直接的MySQL優(yōu)化就是分區(qū)分表,以下是我個(gè)人對(duì)分區(qū)分表的筆記
    2022-09-09
  • PHP MYSQL注入攻擊需要預(yù)防7個(gè)要點(diǎn)

    PHP MYSQL注入攻擊需要預(yù)防7個(gè)要點(diǎn)

    這篇文章主要介紹了PHP MYSQL開發(fā)中,對(duì)于注入攻擊需要預(yù)防的7個(gè)要點(diǎn),大家需要注意了
    2013-11-11
  • mysql數(shù)據(jù)庫(kù)連接失敗常見(jiàn)問(wèn)題小結(jié)

    mysql數(shù)據(jù)庫(kù)連接失敗常見(jiàn)問(wèn)題小結(jié)

    你有沒(méi)有碰到過(guò)mysql數(shù)據(jù)庫(kù)連接不上的問(wèn)題呢?很多的小伙伴表示,經(jīng)常會(huì)時(shí)不時(shí)的出現(xiàn)這些問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于mysql數(shù)據(jù)庫(kù)連接失敗常見(jiàn)問(wèn)題的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • MySQL深入淺出掌握觸發(fā)器用法

    MySQL深入淺出掌握觸發(fā)器用法

    觸發(fā)器是SQLserver提供給程序員和數(shù)據(jù)分析員來(lái)保證數(shù)據(jù)完整性的一種方法,它是與表事件相關(guān)的特殊的存儲(chǔ)過(guò)程,事件是在 MySQL 5.1后引入的,有點(diǎn)類似操作系統(tǒng)的計(jì)劃任務(wù),但是周期性任務(wù)是內(nèi)置在MySQL服務(wù)端執(zhí)行的
    2022-05-05
  • MYSQL與sqlyog連接的實(shí)現(xiàn)

    MYSQL與sqlyog連接的實(shí)現(xiàn)

    本文主要介紹了MYSQL與sqlyog連接的實(shí)現(xiàn),文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-10-10

最新評(píng)論