AWS EKS 收到错误"networkPlugin cni failed to set up pod"



EKS集群版本:

客户端版本:版本。信息{主要:"1",次要:"20",GitVersion:"v1.20.1",GitCommit:"c4d752765b3bbac2237bf87cf0b1c2e307844666",GitTreeState:"clean",BuildDate:"2020-12-19T11:45:27Z",GoVersion:"go1.15.5",编译器:"gc",平台:"linux/amd64"}服务器版本:版本。Info{Major:"1",Minor:"18+",GitVersion:"v1.18.9-eks-d1db3c",GitCommit:"d1db3c46e55f95d6a7d3e578689371318f95ff9",GitTreeState:"clean",BuildDate:"2020-10-20T22:18:07Z",GoVersion:"go1.13.15",编译器:"gc",平台:";linux/amd64"}

下面是我的部署文件:

kind: Deployment
apiVersion: apps/v1
metadata:
name: sample-pod
namespace: front-end
spec:
replicas: 1
selector:
matchLabels:
app: sample-pod
template:
metadata:
labels:
app: sample-pod
spec:
serviceAccountName: my-service-account
containers:
- name: sample-pod
image: <Account-id>.dkr.ecr.us-east-1.amazonaws.com/sample-pod-image:latest
resources:
limits:
cpu: 1000m
memory: 1000Mi
requests:
cpu: 500m
memory: 500Mi
env:
- name: name
value: sample-pod
- name: ACTIVE_SPRING_PROFILE
value: dev
imagePullPolicy: Always
ports:
- name: http
containerPort: 8091
imagePullSecrets:
- name: <my_region>-1-ecr-registry

这是我的案卷。

FROM  amazoncorretto:latest
COPY bootstarp.sh /bootstarp.sh
RUN yum -y install aws-cli 
CMD ["tail", "-f" , "/bootstarp.sh"]

复制步骤:

  1. kubectl应用-f my-dep.yaml
  2. 让容器被创建
  3. 使用命令删除部署kubectl删除-f my-dep.yaml
  4. 使用命令重新创建应用-f my-dep.yaml

不是一个完美的解决方案,但这就是我克服它的方法。

根本原因:部署处于终止阶段,我正在重新创建涉及重新分配网络资源的部署,由于死锁,部署失败。

索恩:我在结束和重新部署之间增加了一段冷静期。早些时候,我在一个镜头中删除并重新创建部署(使用shell脚本(。

早期:

kubectl delete-f my-dep.yaml
some more instructions .....
kubectl apply -f my-dep.yaml

现在:

kubectl delete-f my-dep.yaml
some more instructions .....
**sleep 1m 30s**
kubectl apply -f my-dep.yaml

由于冷却,我现在可以不出所料地部署容器了。

问候Amit Meena

最新更新