一、技术架构
1、架构图
2、解说
mysql_1
、mysql_2
、mysql_3
是一组主从模式,同理mysql_4
、mysql_5
、mysql_6
也是一组主从模式- 从上面的图可以看出
mysql_1
和mysql_4
是主节点,可以进行增删改查操作,但是子几点只能查询操作 - 如果
mysql_1
节点出现问题了,有mysql_4
节点组正常工作
二、创建MYSQL_1
节点
1、使用镜像创建容器
docker run -it -d --name mysql_1 -p 7001:3306 \--net mynet --ip 172.18.0.2 \-m 400m -v /root/mysql_1/data:/var/lib/mysql\-v /root/mysql_1/config:/etc/mysql/conf.d\-e MYSQL_ROOT_PASSWORD=abc123456\-e TZ=Asia/Shanghai --privileged=true\mysql:5.7\--lower_case_table_names=1
2、查看容器是否启动成功
3、在本地使用
navicat
连接远程数据库,创建一个用户4、给当前用户分配权限
5、停止当前的容器,添加配置文件,然后上传到服务器
/root/mysql_1/config
目录下[mysqld]# 数据库字符集character_set_server = utf8# mysql编号(只可以是数字) 每个节点不一样server_id = 1# 开始binlog日志,规定日志文件名称log_bin = mysql_bin# 开启relaylog日志,规定日志文件名称relay_log = relay_bin# 从库的写操作是否写入binlog日志log-slave-updates = 1# 采用严格的SQL语句模式sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
6、重启容器
docker start mysql_1
三、创建MYSQL_2
节点数据库
1、创建数据库容器
docker run -it -d --name mysql_2 -p 7002:3306 \--net mynet --ip 172.18.0.3 \-m 400m -v /root/mysql_2/data:/var/lib/mysql\-v /root/mysql_2/config:/etc/mysql/conf.d\-e MYSQL_ROOT_PASSWORD=abc123456\-e TZ=Asia/Shanghai --privileged=true\mysql:5.7\--lower_case_table_names=1
2、查看是否创建成功
3、停止
MYSQL_2
节点,,添加配置文件,然后上传到服务器/root/mysql_2/config
目录下[mysqld]# 数据库字符集character_set_server = utf8# mysql编号(只可以是数字) 每个节点不一样server_id = 2# 开始binlog日志,规定日志文件名称log_bin = mysql_bin# 开启relaylog日志,规定日志文件名称relay_log = relay_bin# 限制普通账户无法insert、delete、update语句,但是该配置对于管理员账号无效read-only = 1# 采用严格的SQL语句模式sql_mode = NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
4、启动容器
5、测试是否同步
# 停止数据同步服务stop slave;# 设置mysql_1数据库同步change master to master_host="172.18.0.2",master_port=3306,master_user='sync',master_password='abc123456';# 启动服务start slave;# 查看同步状态show slave status;
四、创建MYSQL_3
节点和上面MYSQL_2
节点步骤一样的
五、创建MYSQL_4
节点和上面MYSQL_1
节点步骤一样的
六、创建MYSQL_5
和MYSQL_6
节点和上面创建MYSQL_2
和MYSQL_3
一样的
七、直接在MYSQL_1
中随便创建一个数据库,刷新MYSQL_2
和MYSQL_3
查看数据库是否同步,同理MYSQL_4
、MYSQL_5
、MYSQL_6
也是一样的
八、MYSQL_1
和MYSQL_4
进行关联
1、
MYSQL_1
和MYSQL_4
相互关联2、在
MYSQL_1
的查询中执行以下语句,注意这个地方是要关联到mysql_4
的ip
地址# 停止数据同步服务stop slave;# 设置mysql_1数据库同步change master to master_host="172.18.0.5",master_port=3306,master_user='sync',master_password='abc123456';# 启动服务start slave;# 查看同步状态show slave status;
3、在
mysql_4
中执行以下语句,查看状态# 停止数据同步服务stop slave;# 设置mysql_1数据库同步change master to master_host="172.18.0.2",master_port=3306,master_user='sync',master_password='abc123456';# 启动服务start slave;# 查看同步状态show slave status;
4、在任何一个数据库中创建一个一个数据库和数据表,查看别的是否同步
5、参考文章