一、拉取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配置文件为:
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容器创建成功
此时我们打开docker仪表板可以看到,两个容器已经运行起来了。而且端口就是我们之前创建的对应端口
我们通过navicat连接会报哦1130错误,是因为所连接的用户账户没有远程连接的权限。需要更改mysql数据库里的user表里的host项
把localhost改成%
具体步骤:
?
123456789101112131415161718192021222324252627mysql> 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主数据库配置:
?
123456789101112//进入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从数据库配置:
?
123456789101112131415//进入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也会增加;
?
12345create
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主从数据库内容请搜索快网idc以前的文章或继续浏览下面的相关文章希望大家以后多多支持快网idc!
原文链接:https://www.cnblogs.com/yumaster/p/15737546.html
相关文章
猜你喜欢
- 服务器虚拟化技术深度科普 2025-05-27
- 服务器租用价格怎么计算?服务器租用多少钱一年? 2025-05-27
- 云服务器的“弹性”体现在哪些方面? 2025-05-27
- 刀片服务器是什么 刀片服务器的主要特点 2025-05-27
- 利用FTP和计划任务自动备份网站数据和数据库 2025-05-27
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力! 热门文章
2025-05-27 50Check Point 携手七云网络,共建 SD-WAN 安全解决方案
2025-05-26 109 2025-05-27 23 2025-05-26 47 2025-05-27 99 热门评论