[英]Kubectl apply command for updating existing service resource
目前我使用的是 Kubernetes 版本 1.11.+。 以前我总是对我的云构建脚本使用以下命令:
- name: 'gcr.io/cloud-builders/kubectl'
id: 'deploy'
args:
- 'apply'
- '-f'
- 'k8s'
- '--recursive'
env:
- 'CLOUDSDK_COMPUTE_ZONE=${_REGION}'
- 'CLOUDSDK_CONTAINER_CLUSTER=${_CLUSTER_NAME}'
命令按预期工作,当时我使用的是 k8s 版本 1.10.+。 但是最近我收到以下错误:
- spec.clusterIP:无效值:“”:字段不可变
- metadata.resourceVersion:无效值:“”:必须为更新指定
所以我想知道这是否是服务资源的预期行为?
这是我的服务的 YAML 配置:
apiVersion: v1
kind: Service
metadata:
name: {name}
namespace: {namespace}
annotations:
beta.cloud.google.com/backend-config: '{"default": "{backend-config-name}"}'
spec:
ports:
- port: {port-num}
targetPort: {port-num}
selector:
app: {label}
environment: {env}
type: NodePort
手动运行kubectl apply -f somefile.yaml
时,我有时会遇到此错误。 我认为当有人通过 Kubernetes 仪表板更改规范而不是通过kubectl apply
应用新更改时,就会发生这种情况。
为了修复它,我运行kubectl edit services/servicename
,它在我的默认编辑器中打开了 yaml 规范。 然后删除字段metadata.resourceVersion
和spec.clusterIP
,点击保存并再次运行kubectl apply -f somefile.yaml
。
您需要在服务 yaml 文件中设置 spec.clusterIP,并将其值替换为服务中的 clusterIP 地址,如下所示:
spec:
clusterIP:
您的问题在下面的github 上有讨论,还有一个解决方法可以帮助您绕过这个问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.