• 售前

  • 售后

热门帖子
入门百科

MacOS利用Docker创建MySQL主从数据库的方法

[复制链接]
我是来围观的逊 显示全部楼层 发表于 2022-1-7 15:17:24 |阅读模式 打印 上一主题 下一主题
一、拉取MySQL镜像

通过终端获取最新的MySQL镜像
  1. 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配置文件为:
  1. [mysqld]
  2. server_id = 1
  3. log-bin= mysql-bin
  4. read-only=0
  5. replicate-ignore-db=mysql
  6. replicate-ignore-db=sys
  7. replicate-ignore-db=information_schema
  8. replicate-ignore-db=performance_schema
复制代码
slave从库对应的my.cnf配置文件为:
  1. [mysqld]
  2. server_id = 2
  3. log-bin= mysql-bin
  4. read-only=1
  5. replicate-ignore-db=mysql
  6. replicate-ignore-db=sys
  7. replicate-ignore-db=information_schema
  8. replicate-ignore-db=performance_schema
复制代码
三、创建两个MySQL数据库容器

创建master主数据库容器
  1. 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从数据库容器
  1. 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改成%
详细步调:
  1. mysql> use mysql
  2. Reading table information for completion of table and column names
  3. You can turn off this feature to get a quicker startup with -A
  4. Database changed
  5. mysql> select host from user where user='root';
  6. +-----------+
  7. | host      |
  8. +-----------+
  9. | localhost |
  10. +-----------+
  11. 1 row in set (0.01 sec)
  12. mysql> update user set host='%' where user = 'root';
  13. Query OK, 1 row affected (0.01 sec)
  14. Rows matched: 1  Changed: 1  Warnings: 0
  15. mysql> select host from user where user='root';
  16. +------+
  17. | host |
  18. +------+
  19. | %    |
  20. +------+
  21. 1 row in set (0.00 sec)
  22. mysql> flush privileges;
  23. Query OK, 0 rows affected (0.01 sec)
复制代码
四、主从数据库配置

master主数据库配置:
  1. //进入master主数据容器
  2. docker exec -it mysql-master mysql -uroot -p123456
  3. //创建一个用户来同步数据,每个slave使用标准的MySQL用户名和密码连接master。进行复制操作的用户会授予REPLICATION SLAVE 权限。mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password
  4. CREATE USER 'slave'@'%' IDENTIFIED BY '123456';(这样有可能在slave创建与master连接时报错)
  5. CREATE USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
  6. //对用户进行授权
  7. GRANT REPLICATION SLAVE ON *.* to 'slave'@'%';
  8. //查看状态,记住File、Position的值,在Slave中将用到
  9. show master status;
  10. //查询master容器的IP,会在slave设置主库连接时用到
  11. docker inspect mysql-master | grep IPA;
复制代码
mster的状态,File mysql-bin.000003 Position 661

slave从数据库配置:
  1. //进入slave从数据容器
  2. docker exec -it mysql-slave mysql -uroot -p123456
  3. //设置主库链接 change master to
  4. 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;
  5. //启动从库同步
  6. start slave;
  7. //查看状态
  8. show slave status\G;
  9. //如果 show slave status\G命令结果中出现:
  10. //Slave_IO_Running: Yes
  11. //Slave_SQL_Running: Yes
  12. //以上两项都为Yes,那说明没问题了。
  13. //否则,从新配置从数据
  14. stop slave;
  15. reset slave all;
复制代码
启动从库同步成功

五、主从验证

我们在master上创建一个数据库,然后创建一张表,再插入一条数据,相应的slave也会增长;
  1. create database master_slave_demo;
  2. use master_slave_demo;
  3. create table userinfo(username varchar(50),age int);
  4. insert into userinfo values('Toulon',25);
  5. select * from userinfo;
复制代码
在执行命令之前,主从数据库数目相同;

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

可以发现主库新增的数据已经同步过来了,MySQL的主从复制就设置完成了。(测试环境,MacOS M1 ARM64呆板,Docker,MySQL 8.0.27)
到此这篇关于MacOS使用Docker创建MySQL主从数据库的文章就介绍到这了,更多相关Docker创建MySQL主从数据库内容请搜刮脚本之家以前的文章或继承欣赏下面的相关文章盼望大家以后多多支持脚本之家!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作