gpt4 book ai didi

kubernetes - 节点间的 Pod 到 Pod 通信是不可能的...为什么?

转载 作者:行者123 更新时间:2023-12-03 08:46:51 27 4
gpt4 key购买 nike

我是 k8s 的新手,但我知道,作为 k8s 的要求,每个 Pod 都应该可以从任何其他 Pod 访问。然而,这在我的设置中没有发生:我无法从一个 Pod 内 ping 另一个节点中的另一个 Pod。

这是我的设置:

我有一个主节点 (sauron) 和三个工作节点 (gothmogangmarkhamul) 。我已经通过以下方式安装了 weave 网络:

kubectl apply -f "https://cloud.weave.works/k8s/net?k8s-version=$(kubectl version | base64 | tr -d '\n')"

这是 kubectl get pods -n kube-system -o Wide 的输出

NAME                             READY   STATUS    RESTARTS   AGE    IP                NODE      NOMINATED NODE   READINESS GATES
coredns-5644d7b6d9-bd5qn 1/1 Running 1 59d 10.38.0.2 angmar <none> <none>
etcd-sauron 1/1 Running 44 145d 192.168.201.207 sauron <none> <none>
kube-apiserver-sauron 1/1 Running 82 145d 192.168.201.207 sauron <none> <none>
kube-controller-manager-sauron 1/1 Running 393 145d 192.168.201.207 sauron <none> <none>
kube-proxy-p97vw 1/1 Running 1 134d 192.168.202.235 angmar <none> <none>
kube-proxy-pxpjm 1/1 Running 5 141d 192.168.201.209 gothmog <none> <none>
kube-proxy-rfvcv 1/1 Running 8 145d 192.168.201.207 sauron <none> <none>
kube-proxy-w6p74 1/1 Running 2 141d 192.168.201.213 khamul <none> <none>
kube-scheduler-sauron 1/1 Running 371 145d 192.168.201.207 sauron <none> <none>
weave-net-9sk7r 2/2 Running 0 16h 192.168.202.235 angmar <none> <none>
weave-net-khl69 2/2 Running 0 16h 192.168.201.207 sauron <none> <none>
weave-net-rsntg 2/2 Running 0 16h 192.168.201.213 khamul <none> <none>
weave-net-xk2w4 2/2 Running 0 16h 192.168.201.209 gothmog <none> <none>

这是我的部署 yaml 文件内容:

kind: Deployment
metadata:
name: my-deployment
spec:
replicas: 3
selector:
matchLabels:
app: my-deployment
template:
metadata:
labels:
app: my-deployment
spec:
containers:
- name: my-image
image: my-image:latest
command: ["/bin/bash", "-c", "/opt/tools/bin/myapp"]
imagePullPolicy: IfNotPresent
ports:
- containerPort: 15113
volumeMounts:
- mountPath: /tmp
name: tempdir
imagePullSecrets:
- name: registrypullsecret
volumes:
- name: tempdir
emptyDir: {}

通过 kubectl apply -f mydeployment.yaml 应用部署后,我验证了 Pod 已启动。但就是无法 ping 通其内部 (pod) IP 地址之外的任何内容。

# kubectl get pods -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
my-deployment-77bbb7579c-4cnsk 1/1 Running 0 110s 10.38.0.0 angmar <none> <none>
my-deployment-77bbb7579c-llm2x 1/1 Running 0 110s 10.44.0.2 khamul <none> <none>
my-deployment-77bbb7579c-wbbmv 1/1 Running 0 110s 10.32.0.2 gothmog <none> <none>

似乎无法 ping 通还不够,在 angmar 中运行的 pod my-deployment-77bbb7579c-4cnsk 的 IP 10.38.0.0 ,我觉得这太奇怪了……为什么会这样?

此外,每个容器都有一个 /etc/resolv.conf ,其中包含 nameserver 10.96.0.10,从任何容器内都无法访问它/ pod 。

我应该怎么做才能从 gothmog 中的 pod (10.32.0.2) ping 10.44.0.2(在 khamul 中运行的 pod) ?

更新1:

# kubectl get nodes -o wide
NAME STATUS ROLES AGE VERSION INTERNAL-IP EXTERNAL-IP OS-IMAGE KERNEL-VERSION CONTAINER-RUNTIME
angmar Ready <none> 134d v1.16.3 192.168.202.235 <none> CentOS Linux 7 (Core) 3.10.0-957.10.1.el7.x86_64 docker://1.13.1
gothmog Ready <none> 142d v1.16.2 192.168.201.209 <none> CentOS Linux 7 (Core) 3.10.0-957.10.1.el7.x86_64 docker://1.13.1
khamul Ready <none> 142d v1.16.2 192.168.201.213 <none> CentOS Linux 7 (Core) 3.10.0-957.10.1.el7.x86_64 docker://1.13.1
sauron Ready master 146d v1.16.2 192.168.201.207 <none> CentOS Linux 7 (Core) 3.10.0-957.10.1.el7.x86_64 docker://1.13.1

每个节点上 weave pod 的错误输出包括:索伦(大师):

INFO: 2020/04/08 21:52:31.042120 ->[192.168.202.235:6783|fe:da:ea:36:b0:ea(angmar)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [22:eb:02:7c:
57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)], ours: [fe:5a:2a:52:86:22(sauron)])
INFO: 2020/04/08 21:52:33.675287 ->[192.168.201.209:6783] error during connection attempt: dial tcp :0->192.168.201.209:6783: connect: connection refused
INFO: 2020/04/08 21:52:34.992875 Error checking version: Get https://checkpoint-api.weave.works/v1/check/weave-net?arch=amd64&flag_docker-version=none&flag_kernel-version=3.10.0-957.10.1.el7.x
86_64&flag_kubernetes-cluster-size=3&flag_kubernetes-cluster-uid=428158f7-f097-4627-9dc0-56f5d77a1b3e&flag_kubernetes-version=v1.16.3&flag_network=fastdp&os=linux&signature=TQKdZQISNAlRStpfj1W
vj%2BHWIBhqTt9XQ2czf6xSYNA%3D&version=2.6.2: dial tcp: i/o timeout
INFO: 2020/04/08 21:52:49.640011 ->[192.168.201.209:6783] error during connection attempt: dial tcp :0->192.168.201.209:6783: connect: connection refused
INFO: 2020/04/08 21:52:53.202321 ->[192.168.202.235:6783|fe:da:ea:36:b0:ea(angmar)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [22:eb:02:7c:
57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)], ours: [fe:5a:2a:52:86:22(sauron)])

khamul( worker ):

INFO: 2020/04/09 08:05:52.101683 ->[192.168.201.209:49220|22:eb:02:7c:57:6a(gothmog)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [[663/1858]c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)], ours: [fe:5a:2a:52:86:22(sauron)])
INFO: 2020/04/09 08:06:46.642090 ->[192.168.201.209:6783|22:eb:02:7c:57:6a(gothmog)]: connection shutting down due to error: no working forwarders to 22:eb:02:7c:57:6a(gothmog)
INFO: 2020/04/09 08:08:40.131015 ->[192.168.202.235:6783|fe:da:ea:36:b0:ea(angmar)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [22:eb:02:7c:
57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)], ours: [fe:5a:2a:52:86:22(sauron)])
INFO: 2020/04/09 08:09:39.378853 Error checking version: Get https://checkpoint-api.weave.works/v1/check/weave-net?arch=amd64&flag_docker-version=none&flag_kernel-version=3.10.0-957.10.1.el7.x
86_64&flag_kubernetes-cluster-size=3&flag_kubernetes-cluster-uid=428158f7-f097-4627-9dc0-56f5d77a1b3e&flag_kubernetes-version=v1.16.3&flag_network=fastdp&os=linux&signature=Oarh7uve3VP8qo%2BlV
R6lukCi40hprasXxlwmmBYd5eI%3D&version=2.6.2: dial tcp: i/o timeout
INFO: 2020/04/09 08:09:48.873936 ->[192.168.201.209:6783|22:eb:02:7c:57:6a(gothmog)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [22:eb:02:7c
:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)], ours: [fe:5a:2a:52:86:22(sauron)])
INFO: 2020/04/09 08:11:18.666790 ->[192.168.201.209:45456|22:eb:02:7c:57:6a(gothmog)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [22:eb:02:7
c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)], ours: [fe:5a:2a:52:86:22(sauron)])

gothmog( worker ):

INFO: 2020/04/09 16:50:08.818956 ->[192.168.201.207:6783|fe:5a:2a:52:86:22(sauron)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [fe:5a:2a:52:86:22(sauron)], ours: [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)])
INFO: 2020/04/09 16:52:52.751021 ->[192.168.201.213:54822|e2:f6:ed:71:63:cb(khamul)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [fe:5a:2a:52:86:22(sauron)], ours: [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)])
INFO: 2020/04/09 16:53:18.934143 ->[192.168.201.207:34423|fe:5a:2a:52:86:22(sauron)]: connection shutting down due to error: no working forwarders to fe:5a:2a:52:86:22(sauron)
INFO: 2020/04/09 16:53:49.773876 ->[192.168.201.213:6783|e2:f6:ed:71:63:cb(khamul)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [fe:5a:2a:52:86:22(sauron)], ours: [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)])
INFO: 2020/04/09 16:53:57.784587 ->[192.168.201.207:6783|fe:5a:2a:52:86:22(sauron)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [fe:5a:2a:52:86:22(sauron)], ours: [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)])

angmar( worker ):

INFO: 2020/04/09 16:01:46.081118 ->[192.168.201.207:51620|fe:5a:2a:52:86:22(sauron)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [fe:5a:2a:52
:86:22(sauron)], ours: [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)])
INFO: 2020/04/09 16:01:50.166722 ->[192.168.201.207:6783|fe:5a:2a:52:86:22(sauron)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [fe:5a:2a:52:
86:22(sauron)], ours: [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)])
INFO: 2020/04/09 16:06:48.277791 ->[192.168.201.213:34950|e2:f6:ed:71:63:cb(khamul)]: connection shutting down due to error: read tcp 192.168.202.235:6783->192.168.201.213:34950: read: connect
ion reset by peer
INFO: 2020/04/09 16:07:13.270137 ->[192.168.201.207:58071|fe:5a:2a:52:86:22(sauron)]: connection shutting down due to error: IP allocation was seeded by different peers (received: [fe:5a:2a:52
:86:22(sauron)], ours: [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)])

更新 2:所有 my-deployment pod(无论它们在哪里运行)都包含完全相同的 /etc/resolv.conf 文件:

nameserver 10.96.0.10
search default.svc.cluster.local svc.cluster.local cluster.local testnet.ssd.com
options ndots:5

谢谢!

最佳答案

通过输入每个工作节点并执行以下操作解决了该问题:

rm /var/lib/weave/weave-netdata.db
reboot

说明:

我的编织日志文件显示了摘录:

INFO: 2020/04/08 21:52:31.042120->[192.168.202.235:6783|fe:da:ea:36:b0:ea(angmar)]: connection shutting down due to error: IP allocation was seeded by different peers (received [22:eb:02:7c:57:6a(gothmog) e2:f6:ed:71:63:cb(khamul)], ours: [fe:5a:2a:52:86:22(sauron)])

上面的编织日志输出是通过执行以下操作获得的

kubectl logs -n kube-system <a-weave-pod-id> weave | grep -i error

有关引用,请参阅here .

感谢大家的参与,特别感谢 @kitt 提供的答案。

关于kubernetes - 节点间的 Pod 到 Pod 通信是不可能的...为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61124363/

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