基础环境
Server: Docker Engine - Community
Engine:
Version: 20.10.9
选择镜像
- 好用、可靠
不好用:DOCKER OFFICIAL IMAGE mysql
好用: VERIFIED PUBLISHER bitnami/mysql
部署容器
创建桥接网络
docker network create app-tier --driver bridge
启动容器
- 指定容器名称
- 设置环境变量,指定数据库root初始化密码
- 为容器绑定已经创建的网络类型
- 建立本地路径与容器路径之间的映射
- 建立本地端口与容器端口之间的映射
- 指定镜像名称
- 后台运行
- 默认支持远程主机连接,密码插件是:caching_sha2_password
docker run -d --name dev-mysql -v /opt/docker/mysql/home:/home -v /opt/docker/mysql/home/my_custom.cnf:/opt/bitnami/mysql/conf/bitnami/my_custom.cnf:ro -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --network app-tier bitnami/mysql:8.0.25
创建一个用于连接数据库的容器(已踩坑就是它)
执行SQL,还是走容器靠谱
- 退出时自动删除容器
docker run -it --rm --network app-tier -v /opt/docker/mysql/home:/home bitnami/mysql:8.0.25 mysql -hdev-mysql -uroot -p123456
- 继续执行一个初始化SQL(可选)
source /home/your_sql.sql
坑:以下方式不行
一、进入dev-mysql容器后,使用如下命令登录会失败或者成功,现象这是这样,暂不知道为什么
docker exec -it dev-mysql bash
mysql -h172.24.0.2 -uroot -p123456
或者
docker exec -it <CONTAINER_ID> mysql -uroot -p123456
验证命令
select user,host,plugin from user;
select version();
Docker Compose
Compose file versions and upgrading | Docker Documentation
兼容性矩阵
Compose 文件格式有多个版本 – 1、2、2.x 和 3.x
此表显示了哪些 Compose 文件版本支持特定的 Docker 版本。
Compose file format | Docker Engine release |
---|---|
Compose specification | 19.03.0+ |
3.8 | 19.03.0+ |
3.7 | 18.06.0+ |
3.6 | 18.02.0+ |
3.5 | 17.12.0+ |
3.4 | 17.09.0+ |
3.3 | 17.06.0+ |
3.2 | 17.04.0+ |
3.1 | 1.13.1+ |
3.0 | 1.13.0+ |
2.4 | 17.12.0+ |
2.3 | 17.06.0+ |
2.2 | 1.13.0+ |
2.1 | 1.12.0+ |
2.0 | 1.10.0+ |
v2 和 v3 声明
注意: 指定要使用的 Compose 文件版本时,请确保同时指定主要版本号和次要版本号。如果没有给出次要版本,则默认使用 0 而不是最新的次要版本。因此,将不支持后续版本中添加的功能。例如:
version: "2"
相当于:
version: "2.0"
开启远程访问
MySQL Access denied for user ‘’@’172.17.0.1’(using password: YES) - Many Minds - Medium
MySQL8.0允许外部访问_lemon_cake的博客-CSDN博客_mysql8 远程连接
Docker部署Mysql8.0报错 Access denied for user ‘root‘@‘localhost‘ (using password: YES)_萧道子的博客-CSDN博客
update user set host='%' where user ='root';
#设置密码
#PASSWORD EXPIRE NEVER 密码永不过期
#将默认的插件【caching_sha2_password】修改成【mysql_native_password 】加密插件
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456' PASSWORD EXPIRE NEVER;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;
不区分大小写
[mysqld]
lower_case_table_names=1
lower_case_table_names=0 表名存储为给定的大小和比较是区分大小写的
lower_case_table_names = 1 表名存储在磁盘是小写的,但是比较的时候是不区分大小写
lower_case_table_names=2 表名存储为给定的大小写但是比较的时候是小写的
unix,linux下lower_case_table_names默认值为 0 .Windows下默认值是 1 .Mac OS X下默认值是 2链接:【MySQL】lower_case_table_names参数详解 - 简书 (jianshu.com)
# 进入mysql命令行 执行以下任一语句查看:
show variables like 'lower_case_table_names';
select @@lower_case_table_names;
其它
- 理解 docker 容器中的 uid 和 gid - sparkdev - 博客园 (cnblogs.com)
- 大白话 Docker (新手入门必读) | Server优质外文翻译 | Server 运维论坛 (learnku.com)
- 什么是 Docker - Docker — 从入门到实践 (gitbook.io)