docker将数据从宿主机挂载到容器中的三种方式
在这里插入图片描述

1、volumes:Docker管理宿主机文件系统的一部分(/var/lib/docker/volumes) 保存数据的最佳方式。将容器数据持久化到宿主机,docker自己来管理的一个位置;
volumes特点:

  • 当容器停止或被移除时,该卷依然存在;
  • 当明确删除卷时,卷才会被删除
  • 多个容器之间共享数据;
  • 多个容器可以同时挂载相同的卷
  • 将容器的数据存储在远程主机或其他存储上
  • 将数据从一台docker主机迁移到另一台时,先停止容器,然后备份卷的目录/usr/lib/docker/volumes
  • 相当于宿主机目录软连接到容器中,直接使用
  1. 卷管理
docekr volume ls 		#列出所有数据卷
docker volume create volumename 		#创建数据卷(相当于容器共享存储的位置,删除容器,数据卷不会被删掉)
docker volume inspect imagename 			#查看信息
  • 用卷创建一个容器
docker run -d --name=imagename --mount src=volumename,dst=/usr/share/test/test01 image(最后跟上镜像名)
#src:指定源(使用那个数据卷)
#dst:指定目标(将容器中哪一个目录持久化到数据卷中)

2、bind mounts
将宿主机上的任意位置的文件或目录挂载到容器中;绑定宿主机一个位置挂载到容器的一个目录;如果挂载目标在容器中非空目录,则该目录现有内容将被隐藏;此后所修改的会存在挂载目录中;在挂载前该宿主机目录中尽量不要有数据,保存的是随着容器业务本身所生成的数据

Bind Mounts特点

  • 从主机目录共享配置文件到容器
  • 默认情况下,挂载主机/etc/resolv.conf到每个容器,提供DNS解析
  • 在docker主机上的开发环境和容器之间共享源代码
  • 当docker主机的文件或目录结构保证与容器所需的绑定挂载一致时
#Bind Mounts绑定挂载
docker run -d --name=imagename --mount type=bind,src=/app/www,dst=/usr/share/test/test02 image
#上边指令是将 宿主机的 /usr/share/test/test02目录挂载到容器中的 /app/www下
#type:指定挂载类型         默认是volume 

3、 tmpfs
挂载存储在主机系统的内存中,而不会写入主机的系统文件,如果不希望将数据持久存储在任何位置可以使用tmpfs,同时避免写入容器可写层提高性能

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐