一、拉取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.  
  5. Database changed
  6. mysql> select host from user where user='root';
  7. +-----------+
  8. | host |
  9. +-----------+
  10. | localhost |
  11. +-----------+
  12. 1 row in set (0.01 sec)
  13.  
  14. mysql> update user set host='%' where user = 'root';
  15. Query OK, 1 row affected (0.01 sec)
  16. Rows matched: 1 Changed: 1 Warnings: 0
  17.  
  18. mysql> select host from user where user='root';
  19. +------+
  20. | host |
  21. +------+
  22. | % |
  23. +------+
  24. 1 row in set (0.00 sec)
  25.  
  26. mysql> flush privileges;
  27. 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 monemysql | 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主从数据库的更多相关文章

  1. MacOS使用Docker创建MySQL主主数据库

    主从同步配置可以参考上一篇MacOS使用Docker创建MySQL主从数据库 一.创建MySQL数据库容器配置文件对应目录 我们在当前用户下创建一组目录,用来存放MySQL容器配置文件,(Linux下 ...

  2. Windows系统环境下创建mysql主从数据库方法(双向主从复制)

    创建mysql主从数据库方法(双向主从复制) (一)Windows系统下的MySQL主从复制(单向复制) (1)环境说明: 1,Mysql版本:mysql5.7.20(主从机mysql版本必须一致) ...

  3. 使用docker 实现MySQL主从同步/读写分离

    1. 利用 docker 实现 mysql 主从同步 / 读写分离 为了保证数据的完整和安全,mysql 设计了主从同步,一个挂掉还可以用另个.最近重构论坛,想来改成主从吧.担心失误,就先拿 dock ...

  4. docker安装mysql主从

    docker安装mysql主从 启动主库: 1.docker run --name master -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:5 ...

  5. Docker容器启动Mysql,Docker实现Mysql主从,读写分离

    Docker容器启动Mysql,Docker实现Mysql主从,读写分离 一.Docker文件编排 二.配置主从复制 2.1 配置master 2.2 配置slave 三.验证主从复制 3.1 mas ...

  6. Docker构建mysql主从

    一.为什么要搭建主从架构呢 1.数据安全,可以进行数据的备份. 2.读写分离,大部分的业务系统来说都是读数据多,写数据少,当访问压力过大时,可以把读请求给到从服务器.从而缓解数据库访问的压力 3.故障 ...

  7. springboot多数据源配合docker部署mysql主从实现读写分离

    本篇主要有两部分: 1.使用docker部署mysql主从 实现主从复制 2.springboot项目多数据源配置,实现读写分离 一.使用docker部署mysql主从 实现主从复制 此次使用的是wi ...

  8. MySQL主从数据库同步延迟问题解决(转)

    最近在做MySQL主从数据库同步测试,发现了一些问题,其中主从同步延迟问题是其中之一,下面内容是从网上找到的一些讲解,记录下来以便自己学习: MySQL的主从同步是一个很成熟的架构,优点为:①在从服务 ...

  9. Docker创建MySQL集装箱

    原文链接:Docker创建MySQL集装箱 这样做的目的是创建一个MySQL的image,出来的容器里自己主动启动MySQL服务接受外部连接 步骤: 1. 首先创建一个文件夹并在文件夹下创建一个Doc ...

随机推荐

  1. 数据库之JDBC

    1.简单认识一下JDBC 1).JDBC是什么? java database connection       java数据库连接 作用:就是为了java连接mysql数据库嘛 要详细的,就面向百度编 ...

  2. day08 文件属性

    day08 系统目录 今日内容 一.重要目录 1./usr 2./var 3./proc 二.文件的属性 1.文件属性的介绍 2.文件属性的详述 3.企业案例 /usr 安装第三方软件的目录: 1./ ...

  3. celery开启worker报错django.core.exceptions.ImproperlyConfigured: Requested setting INSTALLED_APPS, but settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE o

    其实挺简单的问题,但花了自己一个下午来解决,先是浏览各种博客,无果:没办法,然后去看celery官方文档,无果,近乎绝望,最后仔细看代码,找到问题所在(如下),自学狗这效率...... 下面是自己ta ...

  4. ERROR 1690 (22003): BIGINT UNSIGNED value is out of range in..的错误 [转]

    问题: ERROR 1690 (22003): BIGINT UNSIGNED value is out of range in..的错误 解决方法: 把没被singed的变量临时变更signed去处 ...

  5. 从jvm字节码指令看i=i++和i=++i的区别

    1. 场景的产生 先来看下下面代码展示的两个场景 @Testvoid testIPP() { int i = 0; for (int j = 0; j < 10; j++) { i = i++; ...

  6. ORACLE 按逗号拆分字符串为多行

    with t as (select '1,2,3,10,11,12' a from dual) select substr(a, decode(level - 1, 0, 0, instr(a, ', ...

  7. PhoneGap打包webApp

    因为我只弄了Andriod的环境,所以在此只以Andriod为例. 使用PhoneGap搭建Android开发的项目整体步骤如下: 安装java环境. 安装ant构建工具. 安装android的开发环 ...

  8. BigDecimal 计算注意事项

    BigDecimal 在进行除法运算(divide)时一定要注意:如果被除数为变量,一定要指定精度 和 舍入模式,否则会报:Non-terminating decimal expansion; no ...

  9. 用oracle中的Row_Number实现分页

    Row_Number实现分页   1:首先是 select ROW_NUMBER() over(order by id asc) as 'rowNumber', * from table1 生成带序号 ...

  10. java实现文件压缩

    java实现文件压缩:主要是流与流之间的传递 代码如下: package com.cst.klocwork.service.zip; import java.io.File; import java. ...