环境:

  • 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

目地:

如果在生产环境中可能有一个主服务器,也是读写服务器,并可能会有多个从服务器,但这个主服务器会随之从服务器的增加而变的性能下降,所以最好主服务器只有一个从,其它的从服务器再从这人从服务器进行复制,减少主服务器的压力,这样中间服务器专做复制从而最小化影响主服务器的性能

步骤:

  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}  
  1. 修改主服务器的配置文件
	[root@master ~]#vi /etc/my.cnf
	[mysqld]
	log-bin=/data/logs/bin
	datadir=/data/mysql
	server-id=17     
  1. 重新启动服务
	[root@master ~]#systemctl start mariadb
  1. 加载一个测试数据库
	[root@master ~]#mysql < hellodb_innodb.sql 
  1. 创建复帽帐号
	MariaDB [(none)]> grant replication slave on *.* to repluser@'192.168.205.%' identified by 'centos';
  1. 备份数据库并拷贝到中间节点中
	[root@master ~]#mysqldump -A --single-transaction --master-data=1 > /data/all.sql
	[root@master ~]#scp /data/all.sql 192.168.205.27:/data 

配置中间级联服务器

  1. 设置中间服务器
	[root@middle ~]#vi /etc/my.cnf           
	[mysqld]
	datadir=/data/mysql
	log-bin=/data/logs/bin
	server-id=27
	read-only
	log_slave_updates
  1. 修改备份的数据
	[root@middle ~]#vi /data/all.sql 
	CHANGE MASTER TO
	MASTER_HOST='192.168.205.17',
	MASTER_USER='repluser',
	MASTER_PASSWORD='centos',                   
	MASTER_PORT=3306,
  1. 导入数据
	MariaDB [(none)]> source /data/all.sql
  1. 启动线程
	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
  1. 备份中间服务器的数据,并拷到从服务器上
	[root@middle ~]#mysqldump -A --single-transaction --master-data=1 > /data/middle.sql
	[root@middle ~]#scp /data/middle.sql 192.168.205.37:/data

修改从服务器

  1. 修改从服务器配置文件
	[root@slave ~]#vi /etc/my.cnf
	[mysqld]
	datadir=/data/mysql
	server-id=37
	read_only
  1. 修改备份的文件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,
  1. 导入数据并启动服务
	[root@slave ~]#mysql < /data/middle.sql   
	[root@slave ~]#systemctl start mariadb
  1. 启动线程
	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)