<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>persistent volume | 伪架构师</title>
    <link>/tags/persistent-volume/</link>
      <atom:link href="/tags/persistent-volume/index.xml" rel="self" type="application/rss+xml" />
    <description>persistent volume</description>
    <generator>Source Themes Academic (https://sourcethemes.com/academic/)</generator><language>zh</language><lastBuildDate>Wed, 01 Jun 2016 22:57:51 +0800</lastBuildDate>
    <image>
      <url>/img/logo-wide.png</url>
      <title>persistent volume</title>
      <link>/tags/persistent-volume/</link>
    </image>
    
    <item>
      <title>Kubernetes 中使用 Gluster FS</title>
      <link>/post/glusterfs-in-kubernetes/</link>
      <pubDate>Wed, 01 Jun 2016 22:57:51 +0800</pubDate>
      <guid>/post/glusterfs-in-kubernetes/</guid>
      <description>

&lt;p&gt;以 RC 形式运行在 Kubernetes 集群中的 Pod，会因为 Scale 等需要在不同的 Node 之间发生迁移，因此需要有独立于 Node 文件系统的共享存储服务，同时这一存储服务也应该符合集群的运行需要，简单的 NFS 不管是效率上还是可靠性上，都是不具备这一能力的。这里以 &lt;a href=&#34;https://www.gluster.org/&#34; target=&#34;_blank&#34;&gt;Gluster FS&lt;/a&gt;  作为存储引擎，为容器集群提供云存储服务。&lt;/p&gt;

&lt;p&gt;K8S 的存储卷使用稍有点古怪，Gluster FS 的使用，需要首先定义一个 &lt;a href=&#34;http://kubernetes.io/docs/user-guide/services/&#34; target=&#34;_blank&#34;&gt;Endpoint + Service&lt;/a&gt; 形式的代理，来定义 Gluster FS 集群，然后就可以通过&lt;a href=&#34;http://blog.fleeto.us/translation/persistent-volumes&#34; target=&#34;_blank&#34;&gt;持久卷&lt;/a&gt;或者用 Pod 直接加载了。&lt;/p&gt;

&lt;h2 id=&#34;定义-service&#34;&gt;定义 Service&lt;/h2&gt;

&lt;p&gt;首先用一个 YML 文件来定义 Endpoint 和 Service：&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;---
kind: List
apiVersion: v1
items:
- kind: Endpoints
  apiVersion: v1
  metadata:
    name: service_name
  subsets:
  - addresses:
    - ip: 12.34.56.78
    ports:
    - port: 111
- kind: Service
  apiVersion: v1
  metadata:
    name: service_name
  spec:
    ports:
      - port: 111
&lt;/code&gt;&lt;/pre&gt;

&lt;ul&gt;
&lt;li&gt;Port 可随意填写&lt;/li&gt;
&lt;li&gt;Service Name 需要一致，这个值将会用到后面的引用中&lt;/li&gt;
&lt;li&gt;ip：Gluster FS 的 IP 地址&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;定义文件生成结束后，利用 &lt;code&gt;kubectl create -f xx.yaml&lt;/code&gt; 的方式加载到集群之中。可以用 &lt;code&gt;kubectl get svc,endpoints&lt;/code&gt; 来验证结果。&lt;/p&gt;

&lt;p&gt;接下来有两种加载方式可以选择：持久卷和 Pod 直接加载。&lt;/p&gt;

&lt;h2 id=&#34;pod-直接加载&#34;&gt;Pod 直接加载&lt;/h2&gt;

&lt;p&gt;可以在 Pod 中直接定义一个 Gluster FS 格式的卷来进行加载：&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;spec:
containers:
- name: nginx-docker-images
  image: nginx:latest
  volumeMounts:
    - mountPath: /glusterfs
      name: test-volume
volumes:
  - name: test-volume
    glusterfs:
      endpoints: glusterfs-cluster
      path: gv0
      readOnly: false
&lt;/code&gt;&lt;/pre&gt;

&lt;ul&gt;
&lt;li&gt;endpoints: 这里指定的就是上一届中定义的服务名称&lt;/li&gt;
&lt;li&gt;path: gluster fs 中的卷名称&lt;/li&gt;
&lt;li&gt;readOnly: 是否只读加载&lt;/li&gt;
&lt;/ul&gt;

&lt;h2 id=&#34;持久卷加载&#34;&gt;持久卷加载&lt;/h2&gt;

&lt;p&gt;首先定义一个持久卷：&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;kind: PersistentVolume
apiVersion: v1
metadata:
  name: gluster-volumen-gv01
spec:
  capacity:
    storage: 1Mi
  accessModes:
    - ReadWriteMany
  glusterfs:
    endpoints: glusterfs-svc
    path: gv0
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;内容同上面的 Pod 卷定义大同小异，具体参数可以参考持久卷的相关文档。&lt;/p&gt;

&lt;p&gt;然后定义一个 PVC&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: myclaim2m
spec:
  accessModes:
    - ReadWriteMany
  resources:
    requests:
      storage: 2Mi
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;最后，在 Pod 中利用 PVC 来进行卷加载&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;volumes:
  - name: test-volume
    persistentVolumeClaim:
      # 上面定义的 PVC 名称
      claimName: myclaim1m
&lt;/code&gt;&lt;/pre&gt;
</description>
    </item>
    
    <item>
      <title>Kubernetes 中的 Persistent Volumes</title>
      <link>/post/pv-in-kubernetes/</link>
      <pubDate>Wed, 01 Jun 2016 09:30:18 +0800</pubDate>
      <guid>/post/pv-in-kubernetes/</guid>
      <description>

&lt;blockquote&gt;
&lt;p&gt;经过一番实验，证明，这东西除了抽象，没啥鸟用，直接挂 Volume 应该是目前最佳选择。&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h1 id=&#34;持久卷-persistentvolumes&#34;&gt;持久卷 PersistentVolumes&lt;/h1&gt;

&lt;p&gt;本文描述了 Kubernetes 中的 &lt;strong&gt;PersistentVolumes&lt;/strong&gt;。要求读者有对卷 (volumes) 所有了解。&lt;/p&gt;

&lt;h2 id=&#34;简介&#34;&gt;简介&lt;/h2&gt;

&lt;p&gt;存储管理跟计算管理是两个不同的问题。&lt;strong&gt;PersistentVolume&lt;/strong&gt; 子系统，对存储的供应和使用做了抽象，以 API 形式提供给管理员和用户使用。要完成这一任务，我们引入了两个新的 API 资源：&lt;strong&gt;PersistentVolume（持久卷）&lt;/strong&gt; 和 &lt;strong&gt;PersistentVolumeClaim（持久卷申请）&lt;/strong&gt;。&lt;/p&gt;

&lt;p&gt;PersistentVolume（PV）是集群之中的一块网络存储。跟 Node 一样，也是集群的资源。PV 跟 Volume (卷) 类似，不过会有独立于 Pod 的生命周期。这一 API 对象包含了存储的实现细节，例如 NFS、iSCSI 或者其他的云提供商的存储系统。&lt;/p&gt;

&lt;p&gt;PersistentVolumeClaim (PVC) 是用户的一个请求。他跟 Pod 类似。Pod 消费 Node 的资源，PVCs 消费 PV 的资源。Pod 能够申请特定的资源（CPU 和 内存）；Claim 能够请求特定的尺寸和访问模式（例如可以加载一个读写，以及多个只读实例）&lt;/p&gt;

&lt;h2 id=&#34;pv-和-pvc-的生命周期&#34;&gt;PV 和 PVC 的生命周期&lt;/h2&gt;

&lt;p&gt;PV 是集群的资源。PVC 是对这一资源的请求，也是对资源的所有权的检验。PV 和 PVC 之间的互动遵循如下的生命周期。&lt;/p&gt;

&lt;h3 id=&#34;供应&#34;&gt;供应&lt;/h3&gt;

&lt;p&gt;集群管理员会创建一系列的 PV。这些 PV 包含了为集群用户提供的真实存储资源。他们可利用 Kubernetes API 来消费。&lt;/p&gt;

&lt;h3 id=&#34;绑定&#34;&gt;绑定&lt;/h3&gt;

&lt;p&gt;用户创建一个包含了容量和访问模式的持久卷申请。Master 会监听 PVC 的产生，并尝试根据请求内容查找匹配的 PV，并把 PV 和 PVC 进行绑定。用户能够获取满足需要的资源，并且在使用过程中可能超出请求数量。&lt;/p&gt;

&lt;p&gt;如果找不到合适的卷，这一申请就会持续处于非绑定状态，一直到出现合适的 PV。例如一个集群准备了很多的 50G 大小的持久卷，（虽然总量足够）也是无法响应 100G 的申请的，除非把 100G 的 PV 加入集群。&lt;/p&gt;

&lt;h3 id=&#34;使用&#34;&gt;使用&lt;/h3&gt;

&lt;p&gt;Pod 把申请作为卷来使用。集群会通过 PVC 查找绑定的 PV，并 Mount 给 Pod。对于支持多种访问方式的卷，用户在使用 PVC 作为卷的时候，可以指定需要的访问方式。&lt;/p&gt;

&lt;p&gt;一旦用户拥有了一个已经绑定的 PVC，被绑定的 PV 就归该用户所有了。用户的 Pods 能够通过在 Pod 的卷中包含的 PVC 来访问他们占有的 PV。&lt;/p&gt;

&lt;h3 id=&#34;释放&#34;&gt;释放&lt;/h3&gt;

&lt;p&gt;当用户完成对卷的使用时，就可以利用 API 删除 PVC 对象了，而且他还可以重新申请。删除 PVC 后，对应的卷被视为 “被释放”，但是这时还不能给其他的 PVC 使用。之前的 PVC 数据还保存在卷中，要根据策略来进行后续处理。&lt;/p&gt;

&lt;h3 id=&#34;回收&#34;&gt;回收&lt;/h3&gt;

&lt;p&gt;PV 的回收策略向集群阐述了在 PVC 释放卷的时候，应如何进行后续工作。目前可以采用三种策略：保留，回收或者删除。保留策略允许重新申请这一资源。在持久卷能够支持的情况下，删除策略会同时删除持久卷以及 AWS EBS/GCE PD 或者 Cinder 卷中的存储内容。如果插件能够支持，回收策略会执行基础的擦除操作（&lt;code&gt;rm -rf /thevolume/*&lt;/code&gt;），这一卷就能被重新申请了。&lt;/p&gt;

&lt;h2 id=&#34;持久卷的类型&#34;&gt;持久卷的类型&lt;/h2&gt;

&lt;p&gt;持久卷是以插件方式实现的，目前支持如下插件：&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;GCEPersistentDisk&lt;/li&gt;
&lt;li&gt;AWSElasticBlockStore&lt;/li&gt;
&lt;li&gt;NFS&lt;/li&gt;
&lt;li&gt;iSCSI&lt;/li&gt;
&lt;li&gt;RBD (Ceph Block Device)&lt;/li&gt;
&lt;li&gt;Glusterfs&lt;/li&gt;
&lt;li&gt;HostPath (单节点测试使用)&lt;/li&gt;
&lt;/ul&gt;

&lt;h2 id=&#34;持久卷&#34;&gt;持久卷&lt;/h2&gt;

&lt;p&gt;每个 PV 包含一个 spec 以及 status ，用于描述该卷的规格和状态。&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;  apiVersion: v1
  kind: PersistentVolume
  metadata:
    name: pv0003
  spec:
    capacity:
      storage: 5Gi
    accessModes:
      - ReadWriteOnce
    persistentVolumeReclaimPolicy: Recycle
    nfs:
      path: /tmp
      server: 172.17.0.2
&lt;/code&gt;&lt;/pre&gt;

&lt;h3 id=&#34;capacity-容量&#34;&gt;Capacity（容量）&lt;/h3&gt;

&lt;p&gt;一般来说，PV 会指定存储容量。这里需要使用 PV 的 &lt;strong&gt;capcity&lt;/strong&gt; 属性。参见 Kubernetes 的 &lt;a href=&#34;https://github.com/kubernetes/kubernetes/blob/release-1.2/docs/design/resources.md&#34; target=&#34;_blank&#34;&gt;Resource Model&lt;/a&gt; 一文，来获取这一属性的计量单位 (Mi/Gi&amp;hellip;.)。&lt;/p&gt;

&lt;p&gt;目前存储大小是唯一一个能够被申请的指标，今后会加入更多属性，例如 IOPS，吞吐能力等。&lt;/p&gt;

&lt;h3 id=&#34;access-modes-访问模式&#34;&gt;Access Modes（访问模式）&lt;/h3&gt;

&lt;p&gt;只要资源提供者支持，持久卷能够被用任何方式加载到主机上。每种存储都会有不同的能力，每个 PV 的访问模式也会被设置成为该卷所支持的特定模式。例如 NFS 能够支持多个读写客户端，但是某个 NFS PV 可能会在服务器上以只读方式使用。每个 PV 都有自己的一系列的访问模式，这些访问模式取决于 PV 的能力。&lt;/p&gt;

&lt;p&gt;访问模式的可选范围如下：&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;ReadWriteOnce&lt;/strong&gt;：该卷能够以读写模式被加载到一个节点上。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;ReadOnlyMany&lt;/strong&gt;：该卷能够以只读模式加载到多个节点上。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;ReadWriteMany&lt;/strong&gt;：该卷能够以读写模式被多个节点同时加载。&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;在 CLI 下，访问模式缩写为：&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;RWO&lt;/strong&gt;：ReadWriteOnce&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;ROX&lt;/strong&gt;：ReadOnlyMany&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;RWX&lt;/strong&gt;：ReadWriteMany&lt;/li&gt;
&lt;/ul&gt;

&lt;blockquote&gt;
&lt;p&gt;重要！一个卷不论支持多少种访问模式，同时只能以一种访问模式加载。例如一个 GCEPersistentDisk 既能支持 ReadWriteOnce ，也能支持 ReadOnlyMany。&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h3 id=&#34;recycling-policy-回收策略&#34;&gt;Recycling Policy（回收策略）&lt;/h3&gt;

&lt;p&gt;当前的回收策略可选值包括：&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Retain - 人工重新申请&lt;/li&gt;
&lt;li&gt;Recycle - 基础擦除（“&lt;code&gt;rm -rf /thevolume/*&lt;/code&gt;”）&lt;/li&gt;
&lt;li&gt;Delete - 相关的存储资产例如 AWS EBS，GCE PD 或者 OpenStack Cinder 卷一并删除。&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;目前，只有 NFS 和 HostPath 支持 Recycle 策略，AWS EBS、GCE PD 以及 Cinder 卷支持 Delete 策略（*其他的都是 Retain 是吧。。*）。&lt;/p&gt;

&lt;h3 id=&#34;阶段-phase&#34;&gt;阶段（Phase）&lt;/h3&gt;

&lt;p&gt;一个卷会处于如下阶段之一：&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Available&lt;/strong&gt;：可用资源，尚未被绑定到 PVC 上&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Bound&lt;/strong&gt;：该卷已经被绑定&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Released&lt;/strong&gt;：PVC 已经被删除，但该资源尚未被集群回收&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Failed&lt;/strong&gt;：该卷的自动回收过程失败。&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;CLI 会显示绑定到该 PV 的 PVC。&lt;/p&gt;

&lt;h2 id=&#34;persistentvolumeclaims-持久卷申请&#34;&gt;PersistentVolumeClaims（持久卷申请）&lt;/h2&gt;

&lt;p&gt;每个 PVC 包含一个 spec 以及 status，用以表达其规格和状态。&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: myclaim
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 8Gi
&lt;/code&gt;&lt;/pre&gt;

&lt;h3 id=&#34;访问模式&#34;&gt;访问模式&lt;/h3&gt;

&lt;p&gt;PVC 使用跟 PV 一致的访问模式。&lt;/p&gt;

&lt;h3 id=&#34;资源&#34;&gt;资源&lt;/h3&gt;

&lt;p&gt;PVC 跟 Pod 一样可以请求特定数量的资源。在这里的请求内容就是存储（storage）。&lt;a href=&#34;https://github.com/kubernetes/kubernetes/blob/release-1.2/docs/design/resources.md&#34; target=&#34;_blank&#34;&gt;Resource Model&lt;/a&gt; 文中提到的内容对 PV 和 PVC 同样适用。&lt;/p&gt;

&lt;h2 id=&#34;pvc-卷&#34;&gt;PVC 卷&lt;/h2&gt;

&lt;p&gt;Pod 能够借助 PVC 来访问存储。PVC 必须跟 Pod 处于同一个命名空间。集群找到 Pod 命名空间中的 PVC，然后利用 PVC 获取到背后的 PV。这个卷就会被加载到主机上，让 Pod 可以使用。&lt;/p&gt;

&lt;pre&gt;&lt;code class=&#34;language-yaml&#34;&gt;kind: Pod
apiVersion: v1
metadata:
  name: mypod
spec:
  containers:
    - name: myfrontend
      image: dockerfile/nginx
      volumeMounts:
      - mountPath: &amp;quot;/var/www/html&amp;quot;
        name: mypd
  volumes:
    - name: mypd
      persistentVolumeClaim:
        claimName: myclaim
&lt;/code&gt;&lt;/pre&gt;
</description>
    </item>
    
  </channel>
</rss>
