Kubernetes volumes简介(2)

  rbd卷可以将Rados Block Device设备映射到pod中。当Pod被移除时,emptyDir卷的内容会被清空,和emptyDir不同,rbd卷的内容还存在着,仅仅是卷被卸载掉而已。也就是说,rbd卷可以其上的数据一起,再次被映射,数据也可以在pod之间传递。
  重要:在使用rbd卷之前,你必须先安装Ceph环境。
  RBD的一个特性就是能够以只读的方式同时映射给多个用户使用。不幸的是,rbd卷只能被一个用户已可读写的模式映射——不能同时允许多个可写的用户使用。
  查看RBD example获取更多细节。

cephfs

  cephfs卷可以将已经存在的CephFS卷映射到pod中。与rbd卷相同,当pod被移除时,cephfs卷的内容还存在着,仅仅是卷被卸载掉而已。另外一点不同的是,CephFS可以同时以可读写的方式映射给多个用户。
  查看CephFS example获取更多细节。

使用subPath

  有时,可以在一个pod中,将同一个卷共享,使其有多个用处。volumeMounts.subPath特性可以用来指定卷中的一个子目录,而不是直接使用卷的根目录。
  这里有一个使用LAMP栈(Linux Apache MySQL PHP)的pod示例,该pod使用了一个共享的卷。HTML内容映射在它的html子目录,而数据库则保存在它的mysql目录。

apiVersion: v1 kind: Pod metadata: name: my-lamp-site spec: containers: - name: mysql image: mysql volumeMounts: - mountPath: /var/lib/mysql name: site-data subPath: mysql - name: php image: php volumeMounts: - mountPath: /var/www/html name: site-data subPath: html volumes: - name: site-data persistentVolumeClaim: claimName: my-lamp-site-data 资源

  emptyDir或者hostPath卷的存储介质(磁盘,SSD等)取决于kubelet根目录(如/var/lib/kubelet)所处文件系统的存储介质。现在没有限制emptyDir或者hostPath卷能使用的空间大小,也没有对容器或者pod的资源隔离。
  未来,我们期望emptyDir或者hostPath卷能够通过resource属性,来请求指定大小的空间,并且选择存储介质类型。

总结

  Kubernetes的volume用于pod内部的数据存储,pod容器内部数据是可以共享的,其生命周期与所属pod生命周期相同。其用处一般是pod生命周期的临时数据存储等。

Docker中部署Kubernetes

Kubernetes集群部署 

OpenStack, Kubernetes, Mesos 谁主沉浮 

Kubernetes集群搭建过程中遇到的问题及解决 

Kubernetes集群部署 

Ubuntu 16.04下安装搭建Kubernetes集群环境 

Ubuntu上手动安装部署Kubernetes详细指南 

Kubernetes 的详细介绍请点这里
Kubernetes 的下载地址请点这里

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/4fd5bd97e914ac8fcc1be37d4b944e6d.html