码迷,mamicode.com
首页 > Web开发 > 详细

实践 Network Policy - 每天5分钟玩转 Docker 容器技术(172)

时间:2018-05-25 10:58:46      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:Kubernetes   Docker   容器   教程   

为了演示 Network Policy,我们先部署一个 httpd 应用,其配置文件 httpd.yaml 为:

技术分享图片

httpd 有三个副本,通过 NodePort 类型的 Service 对外提供服务。部署应用:

技术分享图片

当前没有定义任何 Network Policy,验证应用可以被访问:

  1. 启动一个 busybox Pod,可以访问 Service,也可以 Ping 到副本 Pod。
    技术分享图片

  2. 集群节点可以访问 Service, 也可以 Ping 到副本 Pod。
    技术分享图片

  3. 集群外(192.168.56.1)可以访问 Service。
    技术分享图片

现在创建如下 Network Policy:

技术分享图片

① 定义将此 Network Policy 中的访问规则应用于 label 为 run: httpd 的 Pod,即 httpd 应用的三个副本 Pod。

② ingress 中定义只有 label 为 access: "true" 的 Pod 才能访问应用。

③ 只能访问 80 端口。

通过 kubectl apply 创建 Network Policy。

技术分享图片

验证 Network Policy 的有效性:

  1. busybox Pod 已经不能访问 Service。
    技术分享图片
    如果 Pod 添加了 label access: "true" 就能访问到应用,但 Ping 已经被禁止。
    技术分享图片

  2. 集群节点已经不能访问 Service, 也 Ping 不到副本 Pod。
    技术分享图片

  3. 集群外(192.168.56.1)已经不能访问 Service。
    技术分享图片

如果希望让集群节点和集群外(192.168.56.1)也能够访问到应用,可以对 Network Policy 做如下修改:

技术分享图片

应用新的 Network Policy:

技术分享图片

现在,集群节点和集群外(192.168.56.1)已经能够访问了:

技术分享图片

技术分享图片

除了通过 ingress 限制进入的流量,也可以用 egress 限制外出的流量。大家可以参考官网相关文档和示例,这里就不赘述了。

小结

Kubernetes 采用的是扁平化的网络模型,每个 Pod 都有自己的 IP,并且可以直接通信。

CNI 规范使得 Kubernetes 可以灵活选择多种 Plugin 实现集群网络。

Network Policy 则赋予了 Kubernetes 强大的网络访问控制机制。

书籍:

1.《每天5分钟玩转Kubernetes》
https://item.jd.com/26225745440.html

2.《每天5分钟玩转Docker容器技术》
https://item.jd.com/16936307278.html

3.《每天5分钟玩转OpenStack》
https://item.jd.com/12086376.html

技术分享图片

实践 Network Policy - 每天5分钟玩转 Docker 容器技术(172)

标签:Kubernetes   Docker   容器   教程   

原文地址:http://blog.51cto.com/cloudman/2120115

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!