k8s网络策略

k8s网络策略

k8s网络测试概述

网络策略就是设置防火墙

查看防火墙策略

shell 复制代码
# 获取当前命名空间下的所有 NetworkPolicy 资源(网络策略)
# NetworkPolicy 用于控制 Pod 之间的网络通信规则
kubectl get networkpolicies

# 获取当前命名空间下的所有 NetworkPolicy 资源(简写命令)
# netpol 是 networkpolicies 的缩写,效果与全称命令等价
kubectl get netpol

k8s网络策略网络访问控制案例:

  • 需求:

只允许dev命名空间中的Pod访问test命名空间pod80端口.

  • 分析:
    一个只有specnetwork policy其他条件,意味着进出流全部禁止.
    只允许指定命名空间中的应用访问.

配置k8s网络策略

shell 复制代码
# 编辑k8s网络策略配置文件
vim k8s-networkpolicy.yaml

test 命名空间中创建以下 NetworkPolicy

yaml 复制代码
apiVersion: networking.k8s.io/v1  # 指定使用的 Kubernetes API 版本
kind: NetworkPolicy  # 资源类型为 NetworkPolicy,表示这是一个网络策略对象
metadata:
  name: allow-dev-to-test-80  # 设置该网络策略的名称为 'allow-dev-to-test-80'
  namespace: test  # 指定该网络策略适用于 'test' 命名空间
spec:
  podSelector: {}  # Pod 选择器为空对象,表示该策略适用于 'test' 命名空间下的所有 Pod
  policyTypes:
    - Ingress  # 仅应用于入站流量策略
  ingress:
    - from:
        - namespaceSelector:  # 定义流量来源为特定命名空间
            matchLabels:
              name: dev  # 匹配标签为 'name=dev' 的命名空间
      ports:
        - protocol: TCP  # 允许的协议类型为 TCP
          port: 80  # 允许访问的端口号为 80

保存

shell 复制代码
# 应用网络策略
kubectl apply -f k8s-networkpolicy.yaml

结果验证

shell 复制代码
# 命名空间打标签
kubectl labdel namespace dev name=dev
# 测试
kubectl run busybox --image=busybox -n dev --sleep 12h

# 可以访问
kubectl exec busybox -n dev --wget ${test命名空间pod的ip}

# 不可以访问
kubectl exec busybox --wget ${test命名空间pod的ip}

k8s网络策略配置示例

官方文档

protocolports层级下,只能指定tcp/udp/sctp

yaml 复制代码
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
  # 网络策略名称
  name: allow-port-from-namespace
  namespace: corp-net
spec:
  # 根据标签筛选pod,{}表示所有
  podSelector: {}
  policyTypes:
    # 流方向
    - Ingress
  # Ingress(入pod流量)+from(从哪来)
  ingress:
    - from:
        # 从哪个ns来
        - namespaceSelector:
            # 匹配的label
            matchLabels:
              name: big-corp
      ports:
        # 允许的协议
        - protocol: TCP
	      # 允许的端口
	      port: 9200
相关推荐
日更嵌入式的打工仔5 小时前
EtherCAT 逐帧解析状态机切换过程(初始清零阶段)
网络·信息与通信·ethercat
Danileaf_Guo7 小时前
256台H100服务器的RoCEv2无损与全互联算力网络建设方案
运维·服务器·网络
解压专家6667 小时前
怎么找书?怎么传输?在Kred里完成的全过程
运维·服务器·网络
两个人的幸福online7 小时前
cocos 使用 WebSocket(goEasy版)
网络·websocket·网络协议
yuguo.im8 小时前
Docker 两大基石:Namespace 和 Cgroups
运维·docker·容器
会飞的土拨鼠呀8 小时前
docker部署 outline(栗子云笔记)
笔记·docker·容器
NetInside_9 小时前
2025 DEM 趋势 × NetInside 产品能力:行业深度解读
运维·网络
usrcnusrcn9 小时前
智能建筑的 “隐形神经”:交换机如何连接安防、照明与门禁系统?
运维·服务器·网络
喵了meme9 小时前
C语言实战2
c语言·开发语言·网络
独行soc9 小时前
2025年渗透测试面试题总结-280(题目+回答)
网络·python·安全·web安全·网络安全·渗透测试·安全狮