Docker部署MySQL 5.7&8.0主从集群

发布时间:2024-05-06 点击:107
什么是mysql集群?mysql集群是一个无共享的(shared-nothing)、分布式节点架构的存储方案,其目的是提供容错性和高性能。
> 部署 mysql 5.7 集群 master & slave (仅测试用)
镜像版本 5.7
1、创建 overlay 网络
docker network create --driver overlay common-network --attachable2、编辑两个配置文件 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.7docker 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 status\g如下状态为正常:
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 --attachable2、启动 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 status\g 如下状态为正常:
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


珠海域名注册哪个平台好?什么是高权重域名?
Linux下的压缩解压缩命令
域名已经不在了-备案平台
嘉兴网站设计与制作,企业网站建设中网站首页要如何设计?
此证书由于自签名而不被信任
建立个人网站多少钱?网站建设有哪些基本步骤?
查看域名id的最简单方法
新手站长云服务器哪个好