网站首页 文章专栏 03网络隔离测试.md
03网络隔离测试.md
创建于:2021-07-04 07:48:37 更新于:2024-05-04 02:17:30 羽瀚尘 318

部署应用

# 创建 production staging 命名空间
kubectl create namespace production
kubectl create namespace staging

# 在每个命名空间各部署一套服务
cd kube-router
wget https://raw.githubusercontent.com/mgxian/istio-test/master/service/node/v1/node-v1.yml
wget https://raw.githubusercontent.com/mgxian/istio-test/master/service/go/v1/go-v1.yml
kubectl apply -f node-v1.yml -n production
kubectl apply -f go-v1.yml -n production
kubectl apply -f node-v1.yml -n staging
kubectl apply -f go-v1.yml -n staging

# 查看状态
kubectl get pods --all-namespaces -o wide

输出

production    service-go-v1-6479d45f4-wjhvq               1/1     Running            0          5m16s   10.244.1.66      node02   <none>           <none>
production    service-node-v1-86d99648-skpmc              1/1     Running            0          5m16s   10.244.2.53      node03   <none>           <none>
staging       service-go-v1-6479d45f4-gc9qs               0/1     Running            0          9s      10.244.2.55      node03   <none>           <none>
staging       service-node-v1-86d99648-7lbvj              1/1     Running            0          5m15s   10.244.2.54      node03   <none>           <none>

测试pod通信

获取相关POD信息

PRODUCTION_NODE_NAME=$(kubectl get pods -n production | grep Running | grep service-node | awk '{print $1}')
STAGING_NODE_NAME=$(kubectl get pods -n staging | grep Running | grep service-node | awk '{print $1}')
PRODUCTION_GO_IP=$(kubectl get pods -n production -o wide | grep Running | grep service-go | awk '{print $6}')
STAGING_GO_IP=$(kubectl get pods -n staging -o wide | grep Running | grep service-go | awk '{print $6}')
echo $PRODUCTION_NODE_NAME $PRODUCTION_GO_IP
echo $STAGING_NODE_NAME $STAGING_GO_IP

同namespace的pod通信

kubectl exec -it $PRODUCTION_NODE_NAME --namespace=production -- ping -c4 $PRODUCTION_GO_IP 
kubectl exec -it $STAGING_NODE_NAME --namespace=staging -- ping -c4 $STAGING_GO_IP

4672c95efc9b0029e62db166d9b37f9c

8b0a751df8d686ee4abd7018e34e66f6

不同namespace的pod通信

kubectl exec -it $PRODUCTION_NODE_NAME --namespace=production -- ping -c4 $STAGING_GO_IP
kubectl exec -it $STAGING_NODE_NAME --namespace=staging -- ping -c4 $PRODUCTION_GO_IP

f17c0bde939f113e47ebf32fde009d83

b70b8c94754f1efe23170849f5b32782

结论:任何namespace的任何pod间都可以直接通信

设置默认策略测试

设置默认策略为拒绝所有流量

cat >default-deny.yml<<EOF
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:  
  name: default-deny
spec:  
  podSelector: {}  
  policyTypes:  
  - Ingress
EOF
kubectl apply -f default-deny.yml -n production
kubectl apply -f default-deny.yml -n staging

# 测试通信
# 同namespace的pod通信
kubectl exec -it $PRODUCTION_NODE_NAME --namespace=production -- ping -c4 $PRODUCTION_GO_IP 
kubectl exec -it $STAGING_NODE_NAME --namespace=staging -- ping -c4 $STAGING_GO_IP 

# 不同namespace的pod通信
kubectl exec -it $PRODUCTION_NODE_NAME --namespace=production -- ping -c4 $STAGING_GO_IP
kubectl exec -it $STAGING_NODE_NAME --namespace=staging -- ping -c4 $PRODUCTION_GO_IP

结论:所有pod间都不能通信

设置允许规则

配置

# 设置 service-go 允许从 service-node 访问
cat >service-go-allow-service-node.yml<<EOF
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:  
  name: service-go-allow-service-node
spec:  
  podSelector:    
    matchLabels:      
      app: service-go  
    ingress:  
    - from:    
      - podSelector:        
        matchLabels:          
          app: service-node
EOF
kubectl apply -f service-go-allow-service-node.yml -n production
kubectl apply -f service-go-allow-service-node.yml -n staging

# 设置 service-node 允许 访问 tcp 80 端口
cat >service-node-allow-tcp-80.yml<<EOF
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:  
  name: service-node-allow-tcp-80
spec:  
  podSelector:    
    matchLabels:      
      app: service-node  
  ingress:  
  - from:    
  ports:    
  - protocol: TCP      
  port: 80
EOF

kubectl apply -f service-node-allow-tcp-80.yml -n production
kubectl apply -f service-node-allow-tcp-80.yml -n staging

测试

同namespace的pod通信

kubectl exec -it $PRODUCTION_NODE_NAME --namespace=production -- ping -c4 $PRODUCTION_GO_IP 
kubectl exec -it $STAGING_NODE_NAME --namespace=staging -- ping -c4 $STAGING_GO_IP

d888e8f039901aa08acce3a33a025fd1

626c40f71d6e723ba9f215eaa642972b

不同namespace的pod通信

kubectl exec -it $PRODUCTION_NODE_NAME --namespace=production -- ping -c4 $STAGING_GO_IP
kubectl exec -it $STAGING_NODE_NAME --namespace=staging -- ping -c4 $PRODUCTION_GO_IP

通过service测试

PRODUCTION_GO_SVC=$(kubectl get svc -n production | grep service-go | awk '{print $3}')
STAGING_GO_SVC=$(kubectl get svc -n staging | grep service-go | awk '{print $3}')
echo $PRODUCTION_GO_SVC $STAGING_GO_SVC
curl $PRODUCTION_GO_SVC
curl $STAGING_GO_SVC

结论:同一namespace的pod间可以通信,不同namespace的pod间不可以通信,只允许配置了网络规则的pod间通信.通过 service 也无法绕过网络隔离策略

清理测试环境

# 删除 namespace 自动删除相关资源
kubectl delete ns production
kubectl delete ns staging

参考: