|
网站内容均来自网络,本站只提供信息平台,如有侵权请联系删除,谢谢!
一、拉取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主从数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
x
免责声明
1. 本论坛所提供的信息均来自网络,本网站只提供平台服务,所有账号发表的言论与本网站无关。
2. 其他单位或个人在使用、转载或引用本文时,必须事先获得该帖子作者和本人的同意。
3. 本帖部分内容转载自其他媒体,但并不代表本人赞同其观点和对其真实性负责。
4. 如有侵权,请立即联系,本网站将及时删除相关内容。
|