カスケードレプリケーションデータベース

カスケードレプリケーションデータベース

環境:

  • 192.168.205.17:マスターサーバーとして
  • 192.168.205.27:中央のサーバーなど
  • 192.168.205.37:スレーブサーバとして

バージョン:

  • OS:CentOSのミニと7 1810がインストール
  • mariadb-5.5.60

目地:

マスターサーバーを持っている可能ならば、また、特定のサーバーを読んで、サーバーから複数のパフォーマンスの低下があるかもしれませんが、サーバーから唯一のマスターサーバーを持っていることが最善である本番環境で、増加となるためにプライマリサーバから続きますサーバからコピーされた他のこの圧力人、減少マスタ・サーバ、中間サーバは、マスタのパフォーマンスへの影響を最小限に抑えるために、サーバからコピー専門よう

ステップ:

  1. プライマリサーバを設定します
  2. 中間サーバのバックアップ
  3. サーバからの設定
  4. テスト

プライマリサーバを設定します

  1. インストールされている3台のサーバ
    [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. テスト・データベースをロード
    [root@master ~]#mysql < hellodb_innodb.sql 
  5. 複雑なキャップアカウントの作成
    MariaDB [(none)]> grant replication slave on *.* to repluser@'192.168.205.%' identified by 'centos';
  6. 中間ノードへのバックアップコピーとデータベース
    [root@master ~]#mysqldump -A --single-transaction --master-data=1 > /data/all.sql
    [root@master ~]#scp /data/all.sql 192.168.205.27:/data 

    カスケードサーバ構成真ん中

  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. データバックアップの変更
    [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. データのインポート
    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. 中間データバックアップサーバ、およびサーバからのコピー
    [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. データのインポートやサービスを開始
    [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. 途中で、ノードから各データベースを表示し、同期が成功しています
    MariaDB [(none)]> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | db1                |
    | db2                |
    | hellodb            |
    | mysql              |
    | performance_schema |
    | test               |
    | zhaoli             |
    +--------------------+
    8 rows in set (0.00 sec)

おすすめ

転載: blog.51cto.com/127601/2426823