Docker部署MySQL 5.7&8.0主从集群

 2023-12-24  阅读 2  评论 0

摘要:什么是MySQL集群?MySQL集群是一个无共享的(shared-nothing)、分布式节点架构的存储方案,其目的是提供容错性和高性能。 > 部署 MySQL 5.7 集群 master & slave (仅测试用) 镜像版本 5.7 1、创建 overlay 网络 network create --driver overlay common-network --at

Docker部署MySQL 5.7&8.0主从集群

什么是MySQL集群?MySQL集群是一个无共享的(shared-nothing)、分布式节点架构的存储方案,其目的是提供容错性和高性能。

> 部署 MySQL 5.7 集群 master & slave (仅测试用)

镜像版本 5.7

1、创建 overlay 网络

 network create --driver overlay common-network --attachable

2、编辑两个配置文件 master.cnf 与 slave.cnf

!includedir /etc/mysql/conf.d/  !includedir /etc/mysql/mysql.conf.d/    [mysqld]  log-bin=mysql-bin  server-id=1  gtid-mode=ON  enforce-gtid-consistency=ON  
!includedir /etc/mysql/conf.d/  !includedir /etc/mysql/mysql.conf.d/    [mysqld]  server-id=2  gtid-mode=ON  enforce-gtid-consistency=ON  

3、启动 2 个 MYSQL:mysql-master 、mysql-slave

docker run -d   --name mysql-master   --network common-network   -e MYSQL_ROOT_PASSWORD=Passw0rd   -v `pwd`/master.cnf:/etc/mysql/my.cnf   -p 3306:3306   -d mysql:5.7
docker run -d   --name mysql-slave   --network common-network   -e MYSQL_ROOT_PASSWORD=Passw0rd   -v `pwd`/slave.cnf:/etc/mysql/my.cnf   -p 3307:3306   -d mysql:5.7  

4、添加从库用于复制的用户

docker run -it --rm --network common-network mysql mysql -hmysql-master -uroot -pPassw0rd   -e "CREATE USER 'repl'@'%' IDENTIFIED BY 'password' REQUIRE SSL; "   -e "GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';"

5、连接 master & slave

docker run -it --rm --network common-network mysql mysql -hmysql-slave -uroot -pPassw0rd   -e "CHANGE MASTER TO MASTER_HOST='mysql-master', MASTER_PORT=3306, MASTER_USER='repl', MASTER_PASSWORD='password', MASTER_AUTO_POSITION=1, MASTER_SSL=1;"   -e "START SLAVE;"

6、验证 slave 状态

docker run -it --rm --network common-network mysql mysql -hmysql-slave -uroot -pPassw0rd -e "show slave statusG"

如下状态为正常:

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

> 部署 MySQL 8.0 集群 master & slave(仅测试用)

镜像版本 mysql:8.0

1、创建 overlay 网络

docker network create --driver overlay common-network --attachable

2、启动 2 个 MYSQL:mysql-master 、mysql-slave

docker run -d   --name mysql-master   --network common-network   -e MYSQL_ROOT_PASSWORD=Passw0rd   -p 3306:3306   -d mysql --default-authentication-plugin=mysql_native_password  
docker run -d   --name mysql-slave   --network common-network   -e MYSQL_ROOT_PASSWORD=Passw0rd   -p 3307:3306   -d mysql --default-authentication-plugin=mysql_native_password  

3、配置 master & slave

docker run -it --rm --network common-network mysql mysql -hmysql-master -uroot -pPassw0rd   -e "SET PERSIST server_id=1;"   -e "SET PERSIST_ONLY gtid_mode=ON;"   -e "SET PERSIST_ONLY enforce_gtid_consistency=true; "   -e "CREATE USER 'repl'@'%' IDENTIFIED BY 'password' REQUIRE SSL; "   -e "GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';"  
docker run -it --rm --network common-network mysql mysql -hmysql-slave -uroot -pPassw0rd   -e "SET PERSIST server_id=2;"   -e "SET PERSIST_ONLY gtid_mode=ON;"   -e "SET PERSIST_ONLY enforce_gtid_consistency=true; "  

4、重启 master & slave

docker restart mysql-master mysql-slave  

5、连接 master & slave

docker run -it --rm --network common-network mysql mysql -hmysql-slave -uroot -pPassw0rd   -e "CHANGE MASTER TO MASTER_HOST='mysql-master', MASTER_PORT=3306, MASTER_USER='repl', MASTER_PASSWORD='password', MASTER_AUTO_POSITION=1, MASTER_SSL=1;"   -e "START SLAVE;"  

6、验证 slave 状态

docker run -it --rm --network common-network mysql mysql -hmysql-slave -uroot -pPassw0rd -e "show slave statusG"  

如下状态为正常:

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

> 验证数据同步

在 master 创建数据库 anoyi

docker run -it --rm --network common-network mysql mysql -hmysql-master -uroot -pPassw0rd    -e "create database anoyi default character set utf8mb4 collate utf8mb4_general_ci;"

在 slave 查看数据库列表

docker run -it --rm --network common-network mysql mysql -hmysql-slave -uroot -pPassw0rd    -e "show databases;"  mysql: [Warning] Using a password on the command line interface can be insecure.  +--------------------+  | Database      |  +--------------------+  | anoyi       |  | information_schema |  | mysql       |  | performance_schema |  | sys        |  +--------------------+  

相关资料:

mysql 5.7: https://dev.mysql.com/doc/refman/5.7/en/replication.html

mysql 8.0: https://dev.mysql.com/doc/refman/8.0/en/replication.html

提示:现在腾讯云新人点击注册然后实名认证后,可以点此一键领取2860元代金券,然后点此进入腾讯云活动页面参加优惠力度非常大的腾讯云3年和5年时长服务器活动,一次性买多年,免得续费贵,这样就可以获得最大的优惠折扣,省钱。

版权声明:xxxxxxxxx;

原文链接:https://lecms.nxtedu.cn/yunzhuji/130975.html

发表评论:

验证码

管理员

  • 内容1196554
  • 积分0
  • 金币0
关于我们
lecms主程序为免费提供使用,使用者不得将本系统应用于任何形式的非法用途,由此产生的一切法律风险,需由使用者自行承担,与本站和开发者无关。一旦使用lecms,表示您即承认您已阅读、理解并同意受此条款的约束,并遵守所有相应法律和法规。
联系方式
电话:
地址:广东省中山市
Email:admin@qq.com
注册登录
注册帐号
登录帐号

Copyright © 2022 LECMS Inc. 保留所有权利。 Powered by LECMS 3.0.3

页面耗时0.0107秒, 内存占用362.38 KB, 访问数据库18次

  • 我要关灯
    我要开灯
  • 客户电话
    lecms

    工作时间:8:00-18:00

    客服电话

    电子邮件

    admin@qq.com

  • 官方微信

    扫码二维码

    获取最新动态

  • 返回顶部