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

如果没有显式创建,一个卷会在最开始挂载时被创建。当容器停止时,卷仍然存在。多个容器可以通过read-write或read-only的方式使用同一个卷。
只有在显式删除时,卷才会被删除。如果将一个空卷挂载到容器中一个存有文件或目录的目录中,这些文件或目录会被拷贝到空卷中;如果将一个非空卷挂载到容器中一个存有文件或目录的目录中,这些文件或目录会被隐藏。
使用
当使用docker service create 启动Docker服务时,只支持--mount,不支持-v和--volume。并且每个服务容器使用它们各自的本地卷,因此如果使用本地(local)卷驱动,容器无法通过卷共享数据,但是一些卷驱动支持共享存储。Docker for AWS和Doocker for Azure都使用Cloundstor plugin支持持久存储
- ##
- https://blog.51cto.com/mingongge/5117560