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"]
复制步骤:
- kubectl应用-f my-dep.yaml
- 让容器被创建
- 使用命令删除部署kubectl删除-f my-dep.yaml
- 使用命令重新创建应用-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