Docker数据存储的方法有哪些
今天小编给大家分享一下Docker数据存储的方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
下图展示了volumes,bind mounts和tmpfs mounts三种存储技术的不同:
volumes的使用场景
在多个容器间共享数据。
无法确保docker主机一定拥有某个指定的文件夹或目录结构,使用volumes可以屏蔽这些宿主机差异。
当你希望将数据存储在远程主机或云提供商上。
当你希望备份,恢复或者迁移数据从一台docker主机到另一台docker主机,volumes是更好的选择。
bind mounts的使用场景
在宿主机和容器间共享配置文件。例如将nginx容器的配置文件保存在宿主机上,通过bind mounts挂载后就不用进入容器来修改nginx的配置了。
在宿主机和容器间共享代码或者build输出。例如将宿主机某个项目的target目录挂载到容器中,这样在宿主机上maven build出一个最新的产品,可以直接咋i容器中运行,而不用生成一个新的镜像。
docker主机上的文件或目录结构是确定的
tmpfs mounts的使用场景
当你因为安全或其他原因,不希望将数据持久化到容器或宿主机上,那你可以使用tmpfs mounts模式。
bind mounts和volumes行为上的差异
如果你将一个空volume挂载到一个非空容器目录上,那么这个容器目录中的文件会被复制到volume中,即容器目录原有文件不会被volume覆盖。
如果你使用bind mounts将一个宿主机目录挂载到容器目录上,此容器目录中原有的文件会被隐藏,从而只能读取到宿主机目录下的文件。
以上就是"Docker数据存储的方法有哪些"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。