Docker 存储卷

k8s存储卷和docker的存储卷类似,都是用来提供数据永久存储或数据共享的。不过docker的存储是挂载在容器上,可以伴随荣的生命周期。而k8s的存储卷是挂载在pos上,可以伴随pod的生命周期。因此pod中的容器重启不影响卷。但pod重建时候会影响存储卷。

Docker 提供了3种持久化数据的方式:

  • ​volumes​:存于主机文件系统中的某个区域,由Docker管理(/var/lib/docker/volumes/ on linux)。非Docker进程不应该修改这些数据。卷是Docker中持久化数据的最好方式
  • ​bind mount​:存于主机文件系统中的任意位置。非Docker进程可以修改这些数据
  • ​tmpfs mount​(Linux中):存于内存中(注意,并不是持久化到磁盘)。在容器的生命周期中,它能被容器用来存放非持久化的状态或敏感信息
     

如果没有显式创建,一个卷会在最开始挂载时被创建。当容器停止时,卷仍然存在。多个容器可以通过read-write或read-only的方式使用同一个卷。

只有在显式删除时,卷才会被删除。​如果将一个空卷挂载到容器中一个存有文件或目录的目录中,这些文件或目录会被拷贝到空卷中;如果将一个非空卷挂载到容器中一个存有文件或目录的目录中,这些文件或目录会被隐藏。​

使用

  • 创建:​​docker volume create​​
  • 删除某个卷:​​docker volume rm 卷名​​
  • 删除所有未使用的卷:​​docker volume prune​​
  • 列出所有卷:​​docker volume ls​​
  • 查看某个卷的信息:​​docker volume inspect 卷名​​
  • 挂载到容器:​​-v​​​或​​--volume​​​。如果是Docker17.06或更高:推荐使用​​--mount​​。(同 bind mount)

当使用​​docker service create​​​ 启动Docker服务时,只支持​​--mount​​​,不支持​​-v​​​和​​--volume​​。并且每个服务容器使用它们各自的本地卷,因此如果使用本地(local)卷驱动,容器无法通过卷共享数据,但是一些卷驱动支持共享存储。Docker for AWS和Doocker for Azure都使用Cloundstor plugin支持持久存储

参考

##
https://blog.51cto.com/mingongge/5117560

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叱咤少帅(少帅)

如果文章对你有帮助就打赏下吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值