zoukankan      html  css  js  c++  java
  • 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)

  • 相关阅读:
    vs2015调试慢
    阿里正式发布《Java开发手册》终极版!
    为什么听有些人讲话让人抓狂
    hibernate 映射实例 学生 课程 成绩
    hibernate 树状映射
    hibernate 一对多双向的CURD
    hibernate 多对多双向关联
    hibernate 多对多单向
    hibernate 一对多双向
    hibernate 一对多关联
  • 原文地址:https://www.cnblogs.com/yumaster/p/15737546.html
Copyright © 2011-2022 走看看