Docker之容器数据卷
2021-03-11 本文已影响0人
ljchengx
Docker之安装
Docker之常用命令
Docker之练习
Docker之镜像讲解
Docker之容器数据卷
什么是容器数据卷
Docker理念
讲应用和环境打包成一个镜像
数据?如果数据在容器,我们删除容器,数据也会丢失
需求?
容器之间数据共享的技术
将容器内的目录,挂载到宿主机
容器的持久化和同步操作!容器间的数据也是可以共享的!
使用数据卷
方式一 :直接使用 -v 命令
docker run -it -v 主机目录:容器目录
测试
[root@VM-0-11-centos home]# docker run -it -v /home/ceshi:/home centos /bin/bash
[root@01178346279f /]# cd home
[root@01178346279f home]# ls
[root@01178346279f home]#
[root@VM-0-11-centos home]# ls
ceshi
[root@VM-0-11-centos home]# cd ceshi/
[root@VM-0-11-centos ceshi]# ls
# 通过 inspect 查看内容
[root@VM-0-11-centos ceshi]# docker inspect 01178346279f
image-20210310100135826
这里发现挂载信息
可以测试一下,在容器内创建一个文件然后在宿主机目录下查看 文件是同步的
image-20210310101802876 image-20210310101838385在宿主机内修改文件,容器内的文件也会进行同步。
这里我们在宿主机修改一下test.java 新增内容 "update in linux"
image-20210310101947932然后在容器内查看修改的内容:
image-20210310102050025发现修改的内容,已经同步完成。
总结
双向绑定
实战部署MySQL
# 下载msql
[root@VM-0-11-centos /]# docker pull mysql:5.7
# 运行mysql 需要挂载目录 mysql需要配置密码
# 官方测试 docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
# 启动
# -d 后台运行
# -p 端口映射
# -v 卷挂载
# -e 配置
[root@VM-0-11-centos /]# docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
# 启动成功 测试连接
# 注意端口是宿主机的3310
# 假设此时删除容器 挂载的数据卷依旧存在
image-20210310104201685
进入目录看看挂载的目录:
image-20210310104423982具名挂载与匿名挂载
# 匿名挂载
-v 容器内路径
-P 随机映射端口
docker run -d -P --name nginx01 -v /etc/nginx nginx
# 下载完成 查看所有的卷情况
[root@VM-0-11-centos ~]# docker volumes ls
# 这就是匿名挂载 -v只写了容器内部路径
image-20210310143157904
# 具名方式启动nginx
-v 卷名:容器内路径
[root@VM-0-11-centos ~]# docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx nginx
# 查看卷信息 发现出现了具名
[root@VM-0-11-centos ~]# docker volume ls
DRIVER VOLUME NAME
local d72cd458fa5407bdbcac6cfa1d110fd0f7821ce48e04454da408390a2f37d380
local juming-nginx
local portainer_data
# 查看具名目录 docker volume inspect juming-nginx
[root@VM-0-11-centos ~]# docker volume inspect juming-nginx
[
{
"CreatedAt": "2021-03-10T14:34:49+08:00",
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/juming-nginx/_data",
"Name": "juming-nginx",
"Options": null,
"Scope": "local"
}
]
所有的docker容器内的卷.没有指定目录的情况下都是在 "/var/lib/docker/volumes"
大多数情况下我们使用具名挂载
-v 容器内路径 # 匿名
-v 卷名:容器内路径 # 具名
-v /宿主机路径:容器内路径 # 指定路径挂载
拓展:
# -v 容器内路径: ro/rw 改变读写权限
ro 只读
rw 可读写
# 一旦设置了权限 容器对我们挂载出来的内容就有限定了!
# ro 代表这个路径只能通过宿主机才能操作 容器内无法操作
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx02 -v juming-nginx:/etc/nginx:rw nginx
初识Dockerfile
Dockerfile就是用来构建docker 镜像的文件
命令脚本 先体验一下
# 测试
# mkdir docker-test-volume
[root@VM-0-11-centos home]# mkdir docker-test-volume
[root@VM-0-11-centos home]# ls
ceshi docker-test-volume mysql
# 创建一个dockerfile文件
# 文件中的内容
# 指令(大写) 参数
# 匿名挂载
From centos
VOLUME ["volume01","volume02"]
CMD echo "----end----"
CMD /bin/bash
# 每个命令都是镜像的一层
# 生成
# [root@VM-0-11-centos docker-test-volume]# docker build -f Dockerfile01 -t ljchengx/centos:1.0 .
# 查看 已经生成成功了
[root@VM-0-11-centos docker-test-volume]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
ljchengx/centos 1.0 3e09855b2bc7 47 seconds ago 209MB
nginx latest f6d0b4767a6c 8 weeks ago 133MB
centos latest 300e315adb2f 3 months ago 209MB
# 进入镜像 发现没问题 查看
[root@VM-0-11-centos docker-test-volume]# docker run -it 3e09855b2bc7 /bin/bash
[root@eeaff4c28eb3 /]# ls -l
image-20210310151357249
这里发现我们生成镜像的时候自动挂载的数据卷目录
这个卷和外部卷有同步关系
数据卷容器
多个容器实现数据共享
image-20210310152221125# docker run -it --name docker01 ljchengx/centos:1.0
image-20210310152732130
启动第二个镜像
docker run -it --name docker02 --volumes-from docker01 ljchengx/centos:1.0
image-20210310153515880
此时我们进入docker01的volume01文件夹创建一个文件
[root@VM-0-11-centos ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
e6a2ac185979 ljchengx/centos:1.0 "/bin/sh -c /bin/bash" 56 seconds ago Up 55 seconds docker02
4f087aa4a58f ljchengx/centos:1.0 "/bin/sh -c /bin/bash" 9 minutes ago Up 9 minutes docker01
[root@VM-0-11-centos ~]# docker attach 4f087aa4a58f
[root@4f087aa4a58f /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var volume01 volume02
[root@4f087aa4a58f /]# cd /volume01
[root@4f087aa4a58f volume01]# touch docker01
然后进入docker02查看文件是否同步,此时发现在docker02中出现了docker01创建的文件
[root@VM-0-11-centos ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
e6a2ac185979 ljchengx/centos:1.0 "/bin/sh -c /bin/bash" 2 minutes ago Up 2 minutes docker02
4f087aa4a58f ljchengx/centos:1.0 "/bin/sh -c /bin/bash" 11 minutes ago Up 11 minutes docker01
[root@VM-0-11-centos ~]# docker attach e6a2ac185979
[root@e6a2ac185979 /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var volume01 volume02
[root@e6a2ac185979 /]# cd /volume01
[root@e6a2ac185979 volume01]# ls
docker01
[root@e6a2ac185979 volume01]#