一、mysql容器没有挂载外部配置文件

1、找到容器内部my.cnf的在宿主机的位置,然后修改

[root@node5 mysql]# docker inspect  3257a3b48075 |grep MergedDir
                "MergedDir": "/var/lib/docker/overlay2/ee194186161ddc77e19b87269a3c71a3127046d0bdc7ad3be3d2c9b6cbaf1661/merged",
[root@node5 mysql]# cd "/var/lib/docker/overlay2/ee194186161ddc77e19b87269a3c71a3127046d0bdc7ad3be3d2c9b6cbaf1661/merged"
[root@node5 mysql]# cd etc/mysql/
[root@node5 mysql]# vim my.cnf
[root@node5 mysql]# docker restart 3257a3b48075

3257a3b48075:容器ID
MergedDir: 后面跟的就是在宿主机的位置

2、把宿主机文件拷贝到容器内

2.1 先把容器内的配置文件拷贝出来

#docker cp  容器id:docker容器中配置文件路径   主机文件路径
docker cp  3257a3b48075:/etc/mysql/my.cnf  /home/my.cnf

2.2 修改

vim  /home/my.cnf
#比如咱们添加一个时区测试一下
default-time-zone = '+08:00'

2.3 把文件copy到容器内部,并重启

#docker cp 主机文件路径 容器id:docker容器中配置文件路径
docker cp /home/my.cnf 3257a3b48075:/etc/mysql/my.cnf
docker restart 3257a3b48075

2.4 测试结果

[root@node5 home]# docker exec -it 3257a3b48075 /bin/bash
root@3257a3b48075:/# mysql -uroot -p123456
mysql> show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | UTC    |
| time_zone        | +08:00 |
+------------------+--------+
2 rows in set (0.01 sec)

二、mysql容器挂载外部配置文件
例如:

docker run -d -p 3306:3306 -v /etc/mysql/:/etc/mysql/conf.d/ -v /data/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql_test mysql:5.7.23

直接修改外部配置文件就行,然后restart

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐