Docker管理应用程序数据
将数据从宿主机挂载到容器中的三种方式
Docker提供三种方式将数据从宿主机挂载到容器中:
- volumes:Docker管理宿主机文件系统的一部分(/var/lib/docker/volumes).保存数据的最佳方式
- bind mounts:将宿主机上的任意位置的文件或者目录挂载到容器中
- tmpfs:挂载存储在主机系统的内存中,而不会写入主机的文件系统。如果不希望将数据持久存储在任何位置,可以使用tmpfs,同时避免写入容器可写层提供性能
volumes:
管理卷: # docker volume create nginx-vol # docker volume ls # docker volume inspect nginx-vol 用卷创建一个容器: # docker run -d --name=nginx-test --mount src=nginx-vol,dst=/usr/share/nginx/html nginx # docker run -d --name=nginx-test -v nginx-vol:/usr/share/nginx/html nginx 清理: # docker stop nginx-test # docker rm nginx-test # docker volume rm nginx-vol 注意: 1. 如果没有指定卷,自动创建。 2. 建议使用--mount,更通用
Bind Mounts:
用卷创建一个容器: # docker run -d -it --name=nginx-test --mount type=bind,src=/app/wwwroot,dst=/usr/share/nginx/html nginx # docker run -d -it --name=nginx-test -v /app/wwwroot:/usr/share/nginx/html nginx 验证绑定: # docker inspect nginx-test 清理: # docker stop nginx-test # docker rm nginx-test
批量删除 volumes
docker volume rm $(docker volume ls -qf dangling=true)
注意:
1. 如果源文件/目录没有存在,不会自动创建,会抛出一个错误。
2. 如果挂载目标在容器中非空目录,则该目录现有内容将被隐藏
小结
Volume特点:
- 多个运行容器之间共享数据。
- 当容器停止或被移除时,该卷依然存在。
- 多个容器可以同时挂载相同的卷。
- 当明确删除卷时,卷才会删除。
- 将容器的数据存储在远程主机或其他存储上
- 将数据从一台Docker主机迁移到另一台,先停止容器,然后备份卷的目录(/var/lib/docker/volumes)
Bind Mounts特点:
- 从主机共享配置文件到容器,默认情况下,挂载主机/etc/resolv.conf到每个容器,提供DNS解析。
- 在docker主机上的开发环境和容器之间共享源代码。例如,可以将Maven target目录挂载到容器中,每次在docker主机上构建Maven项目时,容器都可以访问构建的项目包。
- 当docker主机的文件或目录结构保证与容器所需的绑定挂载一致时
需求一(volume):
我nginx有用户上传图片的功能,如果哪一天容器挂掉了,数据就拿不出来了,使用数据卷
可以讲数据存放起来,下次启动,在使用这个数据就不丢失了。
1、创建数据卷:
[root@localhost ~]# docker volume create wwwroot
2、启动一个NGINX容器并且挂载数据卷
[root@localhost ~]# docker run -d --mount src=wwwroot,dst=/usr/share/nginx/html nginx
cba582ee5c7d0a7192296b0699ccad1f004c06cd73547040a2a233126e5fbf6c
[root@localhost ~]#
查看容器数据卷详细情况:
[root@localhost ~]# docker inspect cba582ee5c7d |grep -C 3 _data
{
"Type": "volume",
"Name": "wwwroot",
"Source": "/var/lib/docker/volumes/wwwroot/_data",
"Destination": "/usr/share/nginx/html",
"Driver": "local",
"Mode": "z",
[root@localhost ~]#
需求二(Bind mounts):