我有一个.NET核心的Web应用程序。这已部署到Azure容器注册表。我使用
将其部署到我的Azure Kubernetes服务中kubectl apply -f testdeployment.yaml
带有下面的yaml文件
apiVersion: apps/v1
kind: Deployment
metadata:
name: myweb
spec:
replicas: 1
selector:
matchLabels:
app: myweb
template:
metadata:
labels:
app: myweb
spec:
containers:
- name: myweb
image: mycontainerregistry.azurecr.io/myweb:latest
ports:
- containerPort: 80
imagePullSecrets:
- name: my-registry-key
这很不错,但是当我更改一些代码时,将新代码推送到容器并运行
kubectl应用-f testdeployment
同样,直到我使用以下方式删除部署后,AKS /网站才会更新:
kubectl删除部署myweb
我应该怎么做才能使其覆盖已部署的内容?我想在yaml文件中添加一些内容。 (我试图将其用于Azure DevOps中的连续交付)。
答案 0 :(得分:6)
kubectl
在部署yaml文件中看不到任何更改,因此不会进行任何更改。这是使用latest
标签的问题之一。
将图像标记为某个增量版本或内部版本号,然后在CI管道中将latest
替换为该标记(例如,将其替换为envsubst
或类似名称)。这样kubectl
知道图像已更改。您还知道正在运行什么版本的映像。 latest
标签可以是任何图像版本。
Azure DevOps的简化示例:
# <snippet>
image: mycontainerregistry.azurecr.io/myweb:${TAG}
# </snippet>
管道YAML:
stages:
- stage: Build
jobs:
- job: Build
variables:
- name: TAG
value: $(Build.BuildId)
steps:
- script: |
envsubst '${TAG}' < deployment-template.yaml > deployment.yaml
displayName: Replace Environment Variables
或者,您也可以使用其他工具,例如Replace Tokens(不同的语法:#{TAG}#
)。
答案 1 :(得分:2)
我相信您正在寻找的是imagePullPolicy。默认值为ifNotPresent,这表示将不会提取最新版本。
https://kubernetes.io/docs/concepts/containers/images/
apiVersion: apps/v1
kind: Deployment
metadata:
name: myweb
spec:
replicas: 1
selector:
matchLabels:
app: myweb
template:
metadata:
labels:
app: myweb
spec:
containers:
- name: myweb
image: mycontainerregistry.azurecr.io/myweb
imagePullPolicy: Always
ports:
- containerPort: 80
imagePullSecrets:
- name: my-registry-key
要确保已重新创建Pod,请运行:
kubectl delete -f testdeployment && kubectl apply -f testdeployment
答案 2 :(得分:-1)
这里的问题是,在kubernetes中运行的用于此部署的pod较旧。这就是为什么您看不到应用程序中的更改的原因。
无论何时部署或推送新代码,都必须删除运行中的Pod。然后它将从容器注册表中拉出图像,并且您可以看到您的新更改。
我建议您在应用部署文件后,在CI / CD管道中迈出第一步。如果要手动应用deploy.yml文件,则必须使用以下命令手动删除Pod:kubectl delete pod