容器数据卷
存在问题:
- 如果数据都存放于容器内部,如果容器删除,数据则会丢失
- 容器和容器之间的数据需要共享,Docker中产生的数据则需要同步到本地服务器
为解决该问题则需要学习容器数据卷,容器数据卷可以支持容器的持久化和同步操作,容器之间的数据也可以共享。
使用卷技术
方法一:直接使用命令进行挂载
docker run -it -v 主机目录:容器内目录
#测试
docker run -it -v /home/test:/home centos /bin/bash
此时可以看到,在服务器的/home
下多了一个test
的文件夹
验证镜像在关闭以后也可以同步服务器文件夹下的内容
#1.退出容器
#2.修改对应目录下的文件
#3.查看之前运行镜像的id
#4.启动docker镜像
docker attach 77de302e133a
#5.查看对应目录下的对应文件,此时可以发现在服务器上修改的文件已经同步到容器内
实战:安装MySQL
1.下载MySQL5.7的镜像
docker pull mysql:5.7
2.运行容器,在启动MySQL的时候需要配置密码,在运行是进行数据挂载
docker run -d -p 3355:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name=mysql02 mysql:5.7
此时可以从服务器上查看home
目录下的文件夹,可以看到目前挂载成功
[root@iZ2zefj6kkvtlhfjyf4d09Z ~]# cd /home/
[root@iZ2zefj6kkvtlhfjyf4d09Z home]# ls
mysql test
查看挂载是否成功的另一种方式
docker inspect mysql02
此时可以看到以下信息:
在Navicat中访问服务器中的MySQL镜像,连接成功。
具名和匿名挂载
docker volumes
#可选项
create Create a volume
inspect Display detailed information on one or more volumes
ls List volumes
prune Remove all unused local volumes
rm Remove one or more volumes
- 匿名挂载
# 匿名挂载 -P随机暴露端口,在进行卷挂载的时候并未指明服务器的路径
docker run -d -P --name nginx02 -v /etc/nginx nginx
#查看volume的情况
[root@iZ2zefj6kkvtlhfjyf4d09Z ~]# docker volume ls
DRIVER VOLUME NAME
local e9137e344aa9832a261b652c301f97f81a23e995bac9d37d242747422b054d60
- 具名挂载
[root@iZ2zefj6kkvtlhfjyf4d09Z ~]# docker run -d -P --name nginx03 -v juming-nginx:/etc/nginx nginx
a1342793625b70f1871da72a8c407233ba0180e70bf8d607a3352bc17cf08690
#查看volume
[root@iZ2zefj6kkvtlhfjyf4d09Z ~]# docker volume ls
DRIVER VOLUME NAME
local juming-nginx
#查看挂载到服务器路径
[root@iZ2zefj6kkvtlhfjyf4d09Z ~]# docker volume inspect juming-nginx
[
{
"CreatedAt": "2020-09-23T22:06:33+08:00",
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/juming-nginx/_data",
"Name": "juming-nginx",
"Options": null,
"Scope": "local"
}
]
如果不指定对应的服务器的存放路径则会默认存放于/var/lib/docker/volumes/xxx/_data
目录下
#如何区分挂载的类型
-v 容器内路径 #匿名挂载
-v 卷名/容器内路径 #具名挂载
-v 宿主机路径:容器内路径 #指定路径挂载
拓展
#可以通过添加:ro,rw参数改变挂载内容的权限
docker run -d -P --name nginx03 -v juming-nginx:/etc/nginx:ro nginx
docker run -d -P --name nginx03 -v juming-nginx:/etc/nginx:rw nginx
初识Dockerfile
Dockerfile就是用来构建docker镜像的构建文件,即脚本命令。
通过脚本可以生产对应的镜像,镜像是由一层层的构建,脚本的每一条指令对应一层。
#Dockerfile脚本
FROM centos
VOLUME ['volume01','volume02']
CMD echo ''----end----"
CMD /bin/bash
测试
[root@iZ2zefj6kkvtlhfjyf4d09Z docker-test-volume]# docker build -f /home/docker-test-volume/dockevolume1 -t jerrycentos:2.0 .
Sending build context to Docker daemon 2.048kB
Step 1/4 : FROM centos
---> 0d120b6ccaa8
Step 2/4 : VOLUME ["volume01","volume02"]
---> Running in 3ee681bedcf3
Removing intermediate container 3ee681bedcf3
---> a56b45968490
Step 3/4 : CMD echo ''----end----"
---> Running in bf69f9235d01
Removing intermediate container bf69f9235d01
---> 3f5ae6598de2
Step 4/4 : CMD /bin/bash
---> Running in 01426d0957a5
Removing intermediate container 01426d0957a5
---> 052e34a0423f
Successfully built 052e34a0423f
Successfully tagged jerrycentos:2.0
#查看镜像信息
[root@iZ2zefj6kkvtlhfjyf4d09Z docker-test-volume]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
jerrycentos 2.0 052e34a0423f 14 seconds ago 215MB
#运行新创建的镜像
[root@iZ2zefj6kkvtlhfjyf4d09Z /]# docker run -it 052e34a0423f /bin/bash
#查看容器的文件夹,此时可以看到容器内生成了两个挂载文件夹volume01、volume02
[root@978f54417002 /]# ls -lrt
total 0
drwxr-xr-x 2 root root 6 May 11 2019 srv
lrwxrwxrwx 1 root root 8 May 11 2019 sbin -> usr/sbin
drwxr-xr-x 2 root root 6 May 11 2019 opt
drwxr-xr-x 2 root root 6 May 11 2019 mnt
drwxr-xr-x 2 root root 6 May 11 2019 media
lrwxrwxrwx 1 root root 9 May 11 2019 lib64 -> usr/lib64
lrwxrwxrwx 1 root root 7 May 11 2019 lib -> usr/lib
drwxr-xr-x 2 root root 6 May 11 2019 home
lrwxrwxrwx 1 root root 7 May 11 2019 bin -> usr/bin
drwx------ 2 root root 6 Aug 9 21:40 lost+found
drwxr-xr-x 12 root root 144 Aug 9 21:40 usr
drwxr-xr-x 20 root root 262 Aug 9 21:40 var
drwxr-xr-x 11 root root 163 Aug 9 21:40 run
drwxrwxrwt 7 root root 145 Aug 9 21:40 tmp
dr-xr-x--- 2 root root 162 Aug 9 21:40 root
drwxr-xr-x 1 root root 66 Sep 24 01:31 etc
drwxr-xr-x 2 root root 6 Sep 24 01:31 volume01
drwxr-xr-x 2 root root 6 Sep 24 01:31 volume02
dr-xr-xr-x 113 root root 0 Sep 24 01:31 proc
dr-xr-xr-x 13 root root 0 Sep 24 01:31 sys
drwxr-xr-x 5 root root 360 Sep 24 01:31 dev
可以通过docker inspect 978f54417002
查看对应的挂载的信息,查看后对应的文件可以进行验证,容器内文件可以同步到服务器内的文件夹:
"Mounts": [
{
"Type": "volume",
"Name": "776c78b0aa123ae10d2395c2dc8d8aded2f5fc18c28f4f9616ee221ade7ac338",
"Source": "/var/lib/docker/volumes/776c78b0aa123ae10d2395c2dc8d8aded2f5fc18c28f4f9616ee221ade7ac338/_data",
"Destination": "volume01",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
},
{
"Type": "volume",
"Name": "97e12d134df00c1d1c969f3388d5dd001b326941f57c3ffc7b9d2f9459382526",
"Source": "/var/lib/docker/volumes/97e12d134df00c1d1c969f3388d5dd001b326941f57c3ffc7b9d2f9459382526/_data",
"Destination": "volume02",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
数据同步测试
#利用dockerfile创建的镜像进行测试
docker build -f /home/docker-test-volume/dockevolume1 -t jerrycentos .
#运行该镜像
docker run -it f8cc33a0fb8a /bin/bash
#运行新的镜像,利用--volumes-from进行挂载
docker run -it --name docker01 --volumes-from practical_beaver jerrycentos
#挂载后进行数据同步验证
结论
容器之间配置信息的传递,数据卷容器的生命周期一直持续到没有容器为止,如果数据持续化到本地,本地数据则不会被删除。