Docker数据管理

目录

数据卷

创建数据卷

创建数据卷

查看数据卷

查看指定数据卷的信息

启动一个挂载数据卷的容器

查看数据卷的具体信息

删除数据卷

挂载主机目录

挂载一个主机目录作为数据卷


数据卷

数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 UFS (UNIX File System) ,可以提供很多有用的特性:

  • 数据卷可以在容器之间共享和重用

  • 对数据卷的修改会立马生效

  • 对数据卷的更新,不会影响镜像

  • 数据卷默认会一直存在,即使容器被删除

数据卷的使用,类似于 Linux 下对目录或文件进行 mount,镜像中的被指定为挂载点的目录中的文件会复制到数据卷中(仅数据卷为空时会复制)。

创建数据卷

创建数据卷

docker volume create [volume_name]

查看数据卷

docker volume ls

查看指定数据卷的信息

docker volume inspect [volume_name]

启动一个挂载数据卷的容器

docker run命令启动容器,使用--mount标记将数据卷挂载到容器里,一次docker run可以挂载多个数据卷。

例:创建一个web容器,加载一个数据卷到容器/usr/share/nginx/html目录

可以不需要提前创建好数据卷,直接在运行容器的时候mount 这时如果不存在指定的数据卷,docker会自动创建,自动生成。

–-mount参数说明:

  • source :数据卷
  • target :是容器内文件系统挂载点

查看数据卷的具体信息

docker inspect web

删除数据卷

docker voluem rm [data_volume]

数据卷是被设计用来持久化数据的,它的生命周期独立于容器,Docker 不会在容器被删除后自动删除数据卷,并且也不存在垃圾回收这样的机制来处理没有任何容器引用的数据卷。如果需要在删除容器的同时移除数据卷。可以在删除容器的时候使用命令: docker rm -v。

无主的数据卷可能会占据很多空间,要清理请使用以下命令

docker volume prune

挂载主机目录

挂载一个主机目录作为数据卷

使用--mount标记可以指定挂载一个本地主机的目录到容器中去。

docker run -d -P \
    --name web \
    --mount type=bind,source=/src/webapp,target=/usr/share/nginx/html,readonly \
    nginx:alpine

加载主机的 /src/webapp 目录到容器的 /usr/share/nginx/html目录.使用 --mount 参数时如果本地目录不存在,Docker 会报错。Docker 挂载主机目录的默认权限是 读写,用户也可以通过增加 readonly 指定为只读。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值