docker - 无法使用新映像更新 Minikube 部署
问题描述
我正在运行版本为 v1.15.1 的本地 minikube 集群,Kubernetes 版本为 v1.19.4 和 Docker 19.03.13。本地管理程序是 hyperkit。
我无法使用来自 Docker Hub 的新映像版本更新部署。我正在使用imagePullPolicy: Always
. 图像在 Docker Hub 上明显更新。我将其拉到本地并在 kubernetes 集群外运行映像以进行测试。
我尝试了以下方法在集群内更新但没有成功:
- 删除pod,让kubernetes重启(因为deployment指定了一个replica)
- 通过删除整个部署
kubectl delete deployment service-frontend-voting
kubectl rollout restart deployment service-frontend-voting
通过,进行滚动更新kubectl get pods
表明该 pod 仅几秒钟的历史。不过还是老样子。- 通过更新部署
kubectl set image deployment/service-frontend-voting service-frontend-voting=starax/service-frontend-voting:latest
- 将相同的图像推送到 docker hub 上的新标签并执行步骤 1-3 切换
:latest
到:next
,反之亦然 - 仅使用
:latest
或imagePullPolicy: Always
在部署规范中使用,因为如果指定了其中任何一个,显然 Kubernetes 应该提取图像。
这些方法都没有更新图像。我在这里想念什么?
该应用程序本身是一个简单的 VueJS 应用程序。想要的更改是后端 URL。在生产 vue-js 应用程序中使用环境变量并非易事,因此在此跳过。
Deployment.yaml 供参考:
apiVersion: apps/v1
kind: Deployment
metadata:
name: service-frontend-voting
labels:
app: service-frontend-voting
role: app
spec:
replicas: 1
selector:
matchLabels:
app: service-frontend-voting
template:
metadata:
labels:
app: service-frontend-voting
spec:
containers:
- name: service-frontend-voting
image: starax/service-frontend-voting
ports:
- containerPort: 8080
imagePullPolicy: Always
---
apiVersion: v1
kind: Service
metadata:
name: service-frontend-voting-service
spec:
selector:
app: service-frontend-voting
type: LoadBalancer
ports:
- protocol: TCP
port: 8080
targetPort: 8080
nodePort: 31112
Dockerfile
FROM node:lts-alpine
# install simple http server for serving static content
RUN npm install -g http-server
# make the 'app' folder the current working directory
WORKDIR /app
# copy both 'package.json' and 'package-lock.json' (if available)
COPY package*.json ./
# install project dependencies
RUN npm install
# copy project files and folders to the current working directory (i.e. 'app' folder)
COPY . .
# build app for production with minification
RUN npm run build
EXPOSE 8080
CMD [ "http-server", "dist" ]⏎
解决方案
如果您确实将映像拉到 minikube 集群之外并且成功地将其作为 docker 容器运行.. 那么它应该可以工作(检查IMAGE ID是否是唯一的,否则如果您没有更改 dockerfile 中的任何内容,那么新创建的映像将具有相同的映像ID ) 如果成功创建、标记和上传,如: dockerhub starax/service-frontend-voting:test
您可以执行以下步骤
eval $(minikube docker-env)
docker images
=> 检查图像 ID 和图像名称及其标签docker pull starax/service-frontend-voting:test
=> 这将下载测试标签再次运行
docker images
=> 检查图像 ID、标签是否与之前的 onrd 不同之后在清单文件
kubectl edit deploy service-frontend-voting
更改imagePullPolicy: IfNotPresent
和image: starax/service-frontend-voting:test
注意命令 1. 您使用的不会做任何事情,因为即使您删除了该 pod,部署也会重新创建另一个 pod,新的 pod 将具有部署中指示的图像,该图像与旧版本相同。kubectl describe service-frontend-voting
检查正在使用的图像的名称和标签..
命令2,3会删除,然后创建和之前一样的deployment,拉取的镜像会是starax/service-frontend-voting:latest
更新图像使用 => 4
关于 6,如果你不指定图像的标签,K8s 将使用标签 latest 标签拉取该图像。此外,如果你不指定 imagePullPolicy,则默认情况下策略是 Always ..
还检查kubectl get events
是一个很好的命令来告诉你是否拉了一个新图像
我希望我有所帮助
推荐阅读
- python - 如何使用 groupby 方法计算数据框的平均值
- c# - 如何提高使用 SkiaSharp 绘制大多边形的性能?
- laravel - Laravel Stripe Cashier - 处理取消、数量和宽限期
- r - 如果有一个 R 函数可以从一行中筛选出所有数字
- c# - 在c#中,如何在编译时间中获取类型
- swift - 调用类给出错误 EXC_BAD_INSTRUCTION
- ios - 无法同时满足约束。我不确定哪个代码导致了冲突
- apache-spark - Spark 无法检测到 ES 版本 - 如果网络/Elasticsearch 集群不可访问,通常会发生这种情况
- google-app-engine - 我可以使用负载均衡器/URL 映射器将流量路由到 Google App Engine 还是...?
- swift - Swift 5.+ - 使类可散列?