一、技术架构
-
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、参考文章