小知识:MacOS使用Docker创建MySQL主从数据库的方法

一、拉取mysql镜像

通过终端获取最新的mysql镜像

docker pull mysql/mysql-server

二、创建mysql数据库容器配置文件对应目录

我们在当前用户下创建一组目录,用来存放mysql容器配置文件,(linux下可以省略此步骤)参考下图:

%小知识:MacOS使用Docker创建MySQL主从数据库的方法-猿站网-插图

注意:mysql8版本以后,需要在映射文件中加入 mysql-files,否则mysql数据库容器会创建失败。

因为在macos下不支持vi/vim 直接修改my.cnf文件,也不支持apt-get安装vim,所以需要在本地新建两个my.cnf映射文件。(linux下可以通过vim直接修改配置文件)

master主库对应的my.cnf配置文件为:

?
1
2
3
4
5
6
7
8
[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配置文件为:

?
1
2
3
4
5
6
7
8
[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容器创建成功

%小知识:MacOS使用Docker创建MySQL主从数据库的方法-1猿站网-插图

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

%小知识:MacOS使用Docker创建MySQL主从数据库的方法-2猿站网-插图

我们通过navicat连接会报哦1130错误,是因为所连接的用户账户没有远程连接的权限。需要更改mysql数据库里的user表里的host项

把localhost改成%

具体步骤:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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主数据库配置:

?
1
2
3
4
5
6
7
8
9
10
11
12
//进入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

%小知识:MacOS使用Docker创建MySQL主从数据库的方法-3猿站网-插图

slave从数据库配置:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//进入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;

启动从库同步成功

%小知识:MacOS使用Docker创建MySQL主从数据库的方法-4猿站网-插图

五、主从验证

我们在master上创建一个数据库,然后创建一张表,再插入一条数据,相应的slave也会增加;

?
1
2
3
4
5
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;

在执行命令之前,主从数据库数量相同;

%小知识:MacOS使用Docker创建MySQL主从数据库的方法-5猿站网-插图

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

%小知识:MacOS使用Docker创建MySQL主从数据库的方法-6猿站网-插图

可以发现主库新增的数据已经同步过来了,mysql的主从复制就设置完成了。(测试环境,macos m1 arm64机器,docker,mysql 8.0.27)

到此这篇关于macos使用docker创建mysql主从数据库的文章就介绍到这了,更多相关docker创建mysql主从数据库内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/yumaster/p/15737546.html

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:docker 创建容器时指定容器ip的实现示例

2023-3-12 12:54:12

建站知识

小知识:docker安装rocketMQ和安装过程中出现问题的解决

2023-3-12 13:09:20

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索