環境:
- 192.168.205.17:マスターサーバーとして
- 192.168.205.27:中央のサーバーなど
- 192.168.205.37:スレーブサーバとして
バージョン:
- OS:CentOSのミニと7 1810がインストール
- mariadb-5.5.60
目地:
マスターサーバーを持っている可能ならば、また、特定のサーバーを読んで、サーバーから複数のパフォーマンスの低下があるかもしれませんが、サーバーから唯一のマスターサーバーを持っていることが最善である本番環境で、増加となるためにプライマリサーバから続きますサーバからコピーされた他のこの圧力人、減少マスタ・サーバ、中間サーバは、マスタのパフォーマンスへの影響を最小限に抑えるために、サーバからコピー専門よう
ステップ:
- プライマリサーバを設定します
- 中間サーバのバックアップ
- サーバからの設定
- テスト
プライマリサーバを設定します
- インストールされている3台のサーバ
[root@centos7 ~]#yum install mariadb-server [root@centos7 ~]#mkdir /data/{mysql,logs} [root@centos7 ~]#chown mysql:mysql /data/{mysql,logs}
- マスターサーバーの設定ファイルを変更します。
[root@master ~]#vi /etc/my.cnf [mysqld] log-bin=/data/logs/bin datadir=/data/mysql server-id=17
- サービスの再起動
[root@master ~]#systemctl start mariadb
- テスト・データベースをロード
[root@master ~]#mysql < hellodb_innodb.sql
- 複雑なキャップアカウントの作成
MariaDB [(none)]> grant replication slave on *.* to repluser@'192.168.205.%' identified by 'centos';
- 中間ノードへのバックアップコピーとデータベース
[root@master ~]#mysqldump -A --single-transaction --master-data=1 > /data/all.sql [root@master ~]#scp /data/all.sql 192.168.205.27:/data
カスケードサーバ構成真ん中
- 中間サーバ
[root@middle ~]#vi /etc/my.cnf [mysqld] datadir=/data/mysql log-bin=/data/logs/bin server-id=27 read-only log_slave_updates
- データバックアップの変更
[root@middle ~]#vi /data/all.sql CHANGE MASTER TO MASTER_HOST='192.168.205.17', MASTER_USER='repluser', MASTER_PASSWORD='centos', MASTER_PORT=3306,
- データのインポート
MariaDB [(none)]> source /data/all.sql
- スレッドを開始
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
- 中間データバックアップサーバ、およびサーバからのコピー
[root@middle ~]#mysqldump -A --single-transaction --master-data=1 > /data/middle.sql [root@middle ~]#scp /data/middle.sql 192.168.205.37:/data
サーバーからの変更
- サーバからコンフィギュレーションファイルを変更します。
[root@slave ~]#vi /etc/my.cnf [mysqld] datadir=/data/mysql server-id=37 read_only
- バックアップファイル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,
- データのインポートやサービスを開始
[root@slave ~]#mysql < /data/middle.sql [root@slave ~]#systemctl start mariadb
- スレッドを開始
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
テスト
- プライマリサーバ上のデータベースを構築するテスト
MariaDB [(none)]> create database zhaoli;
Query OK, 1 row affected (0.00 sec)
- 途中で、ノードから各データベースを表示し、同期が成功しています
MariaDB [(none)]> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | db1 | | db2 | | hellodb | | mysql | | performance_schema | | test | | zhaoli | +--------------------+ 8 rows in set (0.00 sec)