溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

數(shù)據(jù)庫的級聯(lián)復制

發(fā)布時間:2020-06-22 12:25:30 來源:網絡 閱讀:356 作者:zhaolinew 欄目:MySQL數(shù)據(jù)庫

數(shù)據(jù)庫的級聯(lián)復制

環(huán)境:

  • 192.168.205.17: as master server
  • 192.168.205.27: as middle server
  • 192.168.205.37: as slave server

版本:

  • OS: centos 7 1810 with mini install
  • mariadb-5.5.60

目地:

如果在生產環(huán)境中可能有一個主服務器,也是讀寫服務器,并可能會有多個從服務器,但這個主服務器會隨之從服務器的增加而變的性能下降,所以最好主服務器只有一個從,其它的從服務器再從這人從服務器進行復制,減少主服務器的壓力,這樣中間服務器專做復制從而最小化影響主服務器的性能

步驟:

  1. 配置主服務器
  2. 備份中間服務器
  3. 配置從服務器
  4. 測試

配置主服務器

  1. 安裝三臺服務器
    [root@centos7 ~]#yum install mariadb-server
    [root@centos7 ~]#mkdir /data/{mysql,logs}
    [root@centos7 ~]#chown mysql:mysql /data/{mysql,logs}  
  2. 修改主服務器的配置文件
    [root@master ~]#vi /etc/my.cnf
    [mysqld]
    log-bin=/data/logs/bin
    datadir=/data/mysql
    server-id=17     
  3. 重新啟動服務
    [root@master ~]#systemctl start mariadb
  4. 加載一個測試數(shù)據(jù)庫
    [root@master ~]#mysql < hellodb_innodb.sql 
  5. 創(chuàng)建復帽帳號
    MariaDB [(none)]> grant replication slave on *.* to repluser@'192.168.205.%' identified by 'centos';
  6. 備份數(shù)據(jù)庫并拷貝到中間節(jié)點中
    [root@master ~]#mysqldump -A --single-transaction --master-data=1 > /data/all.sql
    [root@master ~]#scp /data/all.sql 192.168.205.27:/data 

    配置中間級聯(lián)服務器

  7. 設置中間服務器
    [root@middle ~]#vi /etc/my.cnf           
    [mysqld]
    datadir=/data/mysql
    log-bin=/data/logs/bin
    server-id=27
    read-only
    log_slave_updates
  8. 修改備份的數(shù)據(jù)
    [root@middle ~]#vi /data/all.sql 
    CHANGE MASTER TO
    MASTER_HOST='192.168.205.17',
    MASTER_USER='repluser',
    MASTER_PASSWORD='centos',                   
    MASTER_PORT=3306,
  9. 導入數(shù)據(jù)
    MariaDB [(none)]> source /data/all.sql
  10. 啟動線程
    MariaDB [(none)]> start slave;
    MariaDB [(none)]> show slave status\G
    *************************** 1. row ***************************
                   Slave_IO_State: Waiting for master to send event
                      Master_Host: 192.168.205.17
                      Master_User: repluser
                      Master_Port: 3306
                    Connect_Retry: 60
                  Master_Log_File: bin.000003
              Read_Master_Log_Pos: 7973
                   Relay_Log_File: mariadb-relay-bin.000004
                    Relay_Log_Pos: 604
            Relay_Master_Log_File: bin.000003
                 Slave_IO_Running: Yes
                Slave_SQL_Running: Yes
  11. 備份中間服務器的數(shù)據(jù),并拷到從服務器上
    [root@middle ~]#mysqldump -A --single-transaction --master-data=1 > /data/middle.sql
    [root@middle ~]#scp /data/middle.sql 192.168.205.37:/data

    修改從服務器

  12. 修改從服務器配置文件
    [root@slave ~]#vi /etc/my.cnf
    [mysqld]
    datadir=/data/mysql
    server-id=37
    read_only
  13. 修改備份的文件middle.sql
    [root@slave ~]#vi /data/middle.sql 
    CHANGE MASTER TO 
    MASTER_HOST='192.168.205.27', 
    MASTER_USER='repluser', 
    MASTER_PASSWORD='centos', 
    MASTER_PORT=3306,
  14. 導入數(shù)據(jù)并啟動服務
    [root@slave ~]#mysql < /data/middle.sql   
    [root@slave ~]#systemctl start mariadb
  15. 啟動線程
    MariaDB [(none)]> start salve; 
    MariaDB [(none)]> show slave status\G
    *************************** 1. row ***************************
                   Slave_IO_State: Waiting for master to send event
                      Master_Host: 192.168.205.27
                      Master_User: repluser
                      Master_Port: 3306
                    Connect_Retry: 60
                  Master_Log_File: bin.000005
              Read_Master_Log_Pos: 326
                   Relay_Log_File: mariadb-relay-bin.000003
                    Relay_Log_Pos: 604
            Relay_Master_Log_File: bin.000005
                 Slave_IO_Running: Yes
                Slave_SQL_Running: Yes

測試

  1. 測試在主服務器上建庫
    MariaDB [(none)]> create database zhaoli;
    Query OK, 1 row affected (0.00 sec)
  1. 在中間和從節(jié)點分別查看數(shù)據(jù)庫,同步成功
    MariaDB [(none)]> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | db1                |
    | db2                |
    | hellodb            |
    | mysql              |
    | performance_schema |
    | test               |
    | zhaoli             |
    +--------------------+
    8 rows in set (0.00 sec)
向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI