gpt4 book ai didi

kubernetes - 只允许导出到互联网

转载 作者:行者123 更新时间:2023-12-02 11:56:51 24 4
gpt4 key购买 nike

我有一个坐在边缘的服务。该服务需要通过 Internet 向某处发送一些内容。

我正在使用 Canal CNI。

我可以定义一个只允许导出到互联网而不是集群的其余部分的 NetworkPolicy 吗?

最佳答案

像下面这样的东西会起作用:

kind: NetworkPolicy
apiVersion: networking.k8s.io/v1
metadata:
name: only-allow-internet
spec:
policyTypes:
- Egress
# match all pods in the namespace
podSelector: {}
egress:
- to:
- ipBlock:
# allow all IPs
cidr: 0.0.0.0/0
except:
# except the private IP ranges: https://en.wikipedia.org/wiki/Private_network
- 10.0.0.0/8
- 192.168.0.0/16
- 172.16.0.0/20

它允许所有 IP(因为每个 IP 都匹配 0.0.0.0/0),但 IANA 定义为私有(private) IP 范围的私有(private) IP 范围除外。

请注意,这也会破坏 DNS 查找,因为默认情况下 kubernetes pod 使用 Kubernetes 内部的 DNS 服务器。您可以通过运行以下命令来验证它 pods 内 :
$ nslookup google.com
$ nslookup google.com 8.8.8.8

第一个将超时,而第二个将起作用。

默认情况下,Kubernetes DNS IP 为 10.96.0.10 .您可以通过查看 /etc/resolv.conf 来验证它。一个 pods 内。因此,如果您希望 DNS 查找工作,您可能需要自定义 NetworkPolicy此外,定义更具体的 IP 范围以允许 DNS 查找。

或者,您可以在 pod 定义级别定义 DNS。详情在这里: https://kubernetes.io/docs/concepts/services-networking/dns-pod-service/#pod-s-dns-config

此外,您只能阻止集群 pod/服务范围,而不是阻止所有私有(private) IP 范围。您可以在 kube-apiserver 中找到它们。参数。

关于kubernetes - 只允许导出到互联网,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57203226/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com