MacOS使用Docker创建MySQL主从数据库的方法
一、拉取MySQL镜像
通过终端获取最新的MySQL镜像
docker pull mysql/mysql-server
二、创建MySQL数据库容器配置文件对应目录
我们在当前用户下创建一组目录,用来存放MySQL容器配置文件,(Linux下可以省略此步骤)参考下图:

注意:MySQL8版本以后,需要在映射文件中加入 mysql-files,否则MySQL数据库容器会创建失败。
因为在MacOS下不支持vi/vim 直接修改my.cnf文件,也不支持apt-get安装vim,所以需要在本地新建两个my.cnf映射文件。(Linux下可以通过vim直接修改配置文件)
master主库对应的my.cnf配置文件为:
[mysqld] server_id = 1 log-bin= mysql-bin read-only=0 replicate-ignore-db=mysql replicate-ignore-db=sys replicate-ignore-db=information_schema replicate-ignore-db=performance_schema
slave从库对应的my.cnf配置文件为:
[mysqld] server_id = 2 log-bin= mysql-bin read-only=1 replicate-ignore-db=mysql replicate-ignore-db=sys replicate-ignore-db=information_schema replicate-ignore-db=performance_schema
三、创建两个MySQL数据库容器
创建master主数据库容器
docker run --name mysql-master -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /Users/yumaster/test/mysql_master_slave/master/data:/var/lib/mysql -v /Users/yumaster/test/mysql_master_slave/master/conf/my.cnf:/etc/mysql/my.cnf -v /Users/yumaster/test/mysql_master_slave/master/mysql-files:/var/lib/mysql-files mysql/mysql-server
创建slave从数据库容器
docker run --name mysql-slave -d -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /Users/yumaster/test/mysql_master_slave/slave/data:/var/lib/mysql -v /Users/yumaster/test/mysql_master_slave/slave/conf/my.cnf:/etc/mysql/my.cnf -v /Users/yumaster/test/mysql_master_slave/slave/mysql-files:/var/lib/mysql-files mysql/mysql-server
如下图,说明两个MySQL容器创建成功

此时我们打开Docker仪表板可以看到,两个容器已经运行起来了。而且端口就是我们之前创建的对应端口

我们通过Navicat连接会报哦1130错误,是因为所连接的用户账户没有远程连接的权限。需要更改mysql数据库里的user表里的host项
把localhost改成%
具体步骤:
mysql> use mysql Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A Database changed mysql> select host from user where user='root'; +-----------+ | host | +-----------+ | localhost | +-----------+ 1 row in set (0.01 sec) mysql> update user set host='%' where user = 'root'; Query OK, 1 row affected (0.01 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql> select host from user where user='root'; +------+ | host | +------+ | % | +------+ 1 row in set (0.00 sec) mysql> flush privileges; Query OK, 0 rows affected (0.01 sec)
四、主从数据库配置
master主数据库配置:
//进入master主数据容器 docker exec -it mysql-master mysql -uroot -p123456 //创建一个用户来同步数据,每个slave使用标准的MySQL用户名和密码连接master。进行复制操作的用户会授予REPLICATION SLAVE 权限。mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password CREATE USER 'slave'@'%' IDENTIFIED BY '123456';(这样有可能在slave创建与master连接时报错) 或 CREATE USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; //对用户进行授权 GRANT REPLICATION SLAVE ON *.* to 'slave'@'%'; //查看状态,记住File、Position的值,在Slave中将用到 show master status; //查询master容器的IP,会在slave设置主库连接时用到 docker inspect mysql-master | grep IPA;
mster的状态,File mysql-bin.000003 Position 661

slave从数据库配置:
//进入slave从数据容器 docker exec -it mysql-slave mysql -uroot -p123456 //设置主库链接 change master to change master to master_host='172.17.0.2',master_user='slave',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=661,master_port=3306; //启动从库同步 start slave; //查看状态 show slave status\G; //如果 show slave status\G命令结果中出现: //Slave_IO_Running: Yes //Slave_SQL_Running: Yes //以上两项都为Yes,那说明没问题了。 //否则,从新配置从数据 stop slave; reset slave all;
启动从库同步成功

五、主从验证
我们在master上创建一个数据库,然后创建一张表,再插入一条数据,相应的slave也会增加;
create database master_slave_demo;
use master_slave_demo;
create table userinfo(username varchar(50),age int);
insert into userinfo values('Toulon',25);
select * from userinfo;
在执行命令之前,主从数据库数量相同;

master执行命令之后slave增加对应数据

可以发现主库新增的数据已经同步过来了,MySQL的主从复制就设置完成了。(测试环境,MacOS M1 ARM64机器,Docker,MySQL 8.0.27)
到此这篇关于MacOS使用Docker创建MySQL主从数据库的文章就介绍到这了,更多相关Docker创建MySQL主从数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Windows Server 2016中文版安装docker的详细步骤
因业务需要所以需要安装Docker,但是在途中遇到了一些问题,所以下面这篇文章主要给大家介绍了关于Windows Server 2016中文版安装docker的详细步骤,需要的朋友可以参考下2022-07-07
解决docker网络错误(network bridge not found)
这篇文章主要介绍了解决docker网络错误(network bridge not found)问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-08-08
idea整合docker快速部署springboot应用的详细过程
这篇文章主要介绍了idea整合docker快速部署springboot应用,文中给大家提到关于安装docker步骤,idea连接远程docker的方法,需要的朋友可以参考下2021-10-10
docker.service启动失败:Unit not found的原因及解决办法
这篇文章主要介绍了docker.service启动失败:Unit not found的原因分析及解决办法,需要的朋友可以参考下2017-04-04
使用Docker容器部署MongoDB并支持远程访问及遇到的坑
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的,今天通过本文给大家介绍使用Docker容器部署MongoDB并支持远程访问及遇到的坑,感兴趣的朋友一起看看吧2022-07-07


最新评论