# 获取镜像
docker pull mysql:5.7
# 运行容器,需要做数据挂载!
# 安装MySQL ,需要配置密码的,这是要注意的!
# 官方测试:docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
# 启动我们的
-d 后台运行
-p 端口映射
-v 数据卷挂载
-e 环境配置
--name 容器名字
docker run -d -p 9001:3306 -v /home/mysql/config:/etc/mysql/config.d -v /home/mysql/data:/var/lib/mtsql -e MYSQL_ROOT_PASSWORD=root --name=mysql02 mysql:5.7
# 启动成功之后,我们在本地使用 navicat 链接测试一下
具名和匿名挂载
# 匿名挂载
-v 容器内路径!
docker run -d --name nginx01 -v /ect/nginx nginx
# 查看所有的 volume 的情况
docker volume ls
local 08d733e23f013dd12fee3b470fb436f4c63b7762cd73c87bc5edab566477a0d0
# 这里发现,这种就是匿名挂载,我们在 -v 只写了容器内的路径,没有写容器外的路径!
# 具名挂载
[root@VM-12-7-centos ceshi]# docker run -d -P --name nginx03 -v juming-nginx:/ect/nginx nginx
local juming-nginx
# 通过 -v 卷名:容器内路径
# 查看一下这个卷
所有的docker容器内的卷,没有指定目录的情况下都是在 /var/lib/docker/volumes/ xxx /_data
我们通过具名挂载可以方便的找到我们的一个卷,大多数情况在使用的 具名挂载
# 如何判断是具名还是匿名挂载,还是指定路径挂载
-v 容器内路径 # 匿名挂载
-v 卷名:容器内路径 # 具名挂载
-v /宿主机路径:容器内路径 # 指定路径挂载
拓展:
# 通过 -v 容器内路径: ro rw 改变读写权限
ro readonly # 只读
rw readwrite # 读写
# 一旦设置了这个容器权限,容器对我们挂载出来的内容就有限制了
docker run -d -p --name nginx01 -v /ect/nginx:ro nginx
docker run -d -p --name nginx01 -v /ect/nginx:rw nginx
# ro 只要看见ro就说明这个路径只能通过宿主机来操作,容器内是无法操作的!