如何使用 Kubernetes 里的 NetworkPolicy
data:image/s3,"s3://crabby-images/5df99/5df99f9510e80447149dce60da0811bca21afda2" alt="如何使用Kubernetes里的NetworkPolicy"
创建一个类型为 NetworkPolicy 的 Kubernetes 对象的 yaml 文件。
第九行的 podSelector 指定这个 NetworkPolicy 施加在哪些 pod 上,通过 label 来做 pod 的过滤。
data:image/s3,"s3://crabby-images/e25ac/e25ac6f4de43e13e8a9713f4c2e1c60e0b678145" alt=""
从第 16 行开始的 ingress 定义,定义了只有具备标签 component=ads,module=app 的 pod 才能够连接 component=ads, module=db 的 pod。
首先创建一个临时的 pod,使用正确的 label(component=ads,module=app)去访问 db pod:
kubectl run --restart=Never -it --rm --image=postgres:9.6 --labels="component=ads,module=app" --env="PGCONNECT_TIMEOUT=5" helper --command -- /bin/bash
执行完毕后看到提示 root@helper:/#, 说明我通过上述命令创建的临时 pod 成功的连接到了 postgreSQL 的 pod 上。
data:image/s3,"s3://crabby-images/01416/014161c826429711e86c7a749790ad9eccc113e4" alt=""
输入正确的用户名和密码,能成功连接到 postgreSQL pod 提供的数据库服务上。
data:image/s3,"s3://crabby-images/a0e33/a0e337e346e99b8cecabf8367924b0ddb5f94c3e" alt=""
现在我们重新创建一个临时 pod,不指定 label,因此不满足 NetworkPolicy 里定义的限制条件,因此会看到我们期望的结果:postgreSQL 连接失败。
data:image/s3,"s3://crabby-images/c03a2/c03a2c32370f16f5d638eb252f199e3547382c0c" alt=""
希望通过例子大家能够理解 Kubernetes 里 NetworkPolicy 的工作原理。
通过一个例子学习 Kubernetes 里的 PersistentVolumeClaim 的用法
Kubernetes 的 pod 本身是无状态的(stateless),生命周期通常比较短,只要出现了异常,Kubernetes 就会自动创建一个新的 Pod 来代替它。
而容器产生的数据,会随着 Pod 消亡而自动消失。
为了实现 Pod 内数据的存储管理,Kubernetes 引入了两个 API 资源:Persistent Volume(持久卷,以下简称 PV)和 Persistent Volume Claim(持久卷申请,以下简称 PVC)。
PV 是 Kubernetes 集群中的一种网络存储实现,跟 Node 一样,也是属于集群的资源。
PV 跟 Docker 里的 Volume(卷)类似,不过会有独立于 Pod 的生命周期。
使用 kubectl get pv 查看列表:
data:image/s3,"s3://crabby-images/6d504/6d504f3a09d7a71ae397ebadb58b6d1e36db6ecc" alt=""
而 PVC 是用户的一个请求,跟 Pod 类似。Pod 消费 Node 的资源,PVC 消费 PV 的资源。
data:image/s3,"s3://crabby-images/025b4/025b4861e71c2948d1e7a000977c1c07b69e2251" alt=""
Pod 能够申请特定的资源(CPU 和内存);PVC 能够申请特定的尺寸和访问模式,例如可以加载一个读写实例或者多个只读实例,(就是上图 kubectl get pvc 返回结果的 Access Mode 这一列的值 RWO, ROX 等等)而无须感知这些实例背后具体的存储实现。
我们来看一个具体的 PVC 实例,名称为 nginx-pvc:
kind: PersistentVolumeClaim apiVersion: v1 metadata: name: nginx-pvc spec: storageClassName: default accessModes: - ReadOnlyMany resources: requests: storage: 1Gi
data:image/s3,"s3://crabby-images/17094/170945b7e2b9847c17400cac8b3f126d232db987" alt=""
使用命令 kubectl create -f pvc.yaml 创建这个 yaml 文件定义的 persistent volume claim:
data:image/s3,"s3://crabby-images/8ce9b/8ce9bbbcf26eed40f4bfc242926f430ed38a3828" alt=""
然后定义一个 pod,消费这个名为 nginx-pvc 的 persistent volume claim:
data:image/s3,"s3://crabby-images/0f2d4/0f2d4ac577c2b032dc288b6f9014972020a0d669" alt=""
data:image/s3,"s3://crabby-images/3da8e/3da8e00c6dc427c315f4ac4d1c3690e57e7de2d6" alt=""
使用 kubectl describe pvc nginx-pvc 查看这个 persistent volume claim 对应生成的 persistent volume:
data:image/s3,"s3://crabby-images/6f569/6f5697ee2af8850915b078be55b663127e184772" alt=""
data:image/s3,"s3://crabby-images/accd8/accd8b07e97b7919bd8d6ed4d9802c60a7a0845d" alt=""
现在我用命令 kubectl cp train.jpg nginx-storage-pod:/usr/share/nginx/html 将两个文件 train.jpg 和 index.html 文件拷贝到 pod 内部文件路径/usr/share/nginx/html 下面:
data:image/s3,"s3://crabby-images/34a6a/34a6aaa3db4aae7e75802379b8f720d051bec44e" alt=""
现在切换到 nginx-storage-pod pod 里,在/usr/share/nginx/html 目录下果然发现了这两个文件:
data:image/s3,"s3://crabby-images/16cc3/16cc38dff1218b87bda360f00f0fdb2f8b9bb758" alt=""
接下来我定义了另一个 pod,同样适用 nginx-pvc 这个 PVC:
data:image/s3,"s3://crabby-images/a9d35/a9d35543e4f01cc4aca28d7d764728f389b84132" alt=""
创建完这个 pod 之后,then kubectl exec -ti another ash 进入 pod 内部/usr/share/nginx/html,同样发现了 index.html 和 train.jpg.
data:image/s3,"s3://crabby-images/f489d/f489d717a97664ee2174bae83be882f90ca1c305" alt=""
这个例子说明 persistent volume claim 能够用于在多个 pod 间共享持久化数据。要获取更多 Jerry 的原创文章,请关注公众号"汪子熙":
data:image/s3,"s3://crabby-images/73729/737294d6792cb3b5551a5dad0049bebfbfda2f9f" alt=""
版权声明: 本文为 InfoQ 作者【Jerry Wang】的原创文章。
原文链接:【http://xie.infoq.cn/article/bc373ca2e2f9dc128df01617a】。文章转载请联系作者。
评论