一、技术架构

  • 1、架构图

  • 2、解说

    • mysql_1mysql_2mysql_3是一组主从模式,同理mysql_4mysql_5mysql_6也是一组主从模式
    • 从上面的图可以看出mysql_1mysql_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_5MYSQL_6节点和上面创建MYSQL_2MYSQL_3一样的

七、直接在MYSQL_1中随便创建一个数据库,刷新MYSQL_2MYSQL_3查看数据库是否同步,同理MYSQL_4MYSQL_5MYSQL_6也是一样的

八、MYSQL_1MYSQL_4进行关联

  • 1、MYSQL_1MYSQL_4相互关联

  • 2、在MYSQL_1的查询中执行以下语句,注意这个地方是要关联到mysql_4ip地址

    # 停止数据同步服务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、参考文章