gpt4 book ai didi

kubernetes-helm - 为什么 helm 不使用部署模板中定义的名称?

转载 作者:行者123 更新时间:2023-12-02 03:26:03 24 4
gpt4 key购买 nike

即来自 name: {{ .Chart.Name }}-{{ .Values.module5678.name }}-pod 下面

# deployment.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: {{ template "project1234.name" . }}
chart: {{ template "project1234.chart" . }}
release: {{ .Release.Name }}
heritage: {{ .Release.Service }}
name: {{ template "project1234.module5678.fullname" . }}
spec:
replicas: {{ .Values.replicaCount }}
selector:
matchLabels:
app: {{ template "project1234.name" . }}
template:
metadata:
labels:
app: {{ template "project1234.name" . }}
spec:
containers:
- image: "{{ .Values.image.name }}:{{ .Values.image.tag }}"
name: {{ .Chart.Name }}-{{ .Values.module5678.name }}-pod
ports:
- containerPort: 1234
imagePullSecrets:
- name: {{ .Values.image.pullSecret }}

我希望 pod 名称是:

pod/project1234-module5678-pod

相反,生成的 Pod 名称是:

pod/chartname-project1234-module5678-dc7db787-skqvv

...哪里(据我所知):
chartname 来自:helm install --name chartname -f values.yaml .
project1234 来自:

# Chart.yaml

apiVersion: v1
appVersion: "1.0"
description: project1234 Helm chart for Kubernetes
name: project1234
version: 0.1.0

module5678 来自:

# values.yaml

rbac:
create: true

serviceAccounts:
module5678:
create: true
name:

image:
name: <image location>
tag: 1.5
pullSecret: <pull secret>

gitlab:
secretName: <secret name>
username: foo
password: bar

module5678:
enabled: true
name: module5678
ingress:
enabled: true
replicaCount: 1
resources: {}

我尝试将 name: {{ .Chart.Name }}-{{ .Values.module5678.name }}-pod 更改为纯字符串值,如“podname1234”,但它不是'跟着。我什至尝试完全删除名称设置,结果 pod 名称保持不变。

最佳答案

从 Deployment 创建的 Pod 总是有一个基于 Deployment 名称的生成名称(如果你去寻找它,还有中间 ReplicaSet 的名称)。您无法覆盖它。

鉴于您展示的 YAML,我希望这个片段:

apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ template "project1234.module5678.fullname" . }}

展开为 chartname-project1234-module5678 的 Deployment 名称;其余位由 ReplicaSet 添加,然后由 Pod 本身添加。

如果您查看 Pod 和kubectl describe pod chartname-project1234-module5678-dc7db787-skqvv,您可能会看到它有一个具有预期名称的容器 project1234- module5678-pod。几乎只有当你需要在多容器 pod 中 kubectl logs(或者更罕见的情况下,kubectl exec)时才需要使用它;如果您属于这种情况,您会喜欢使用较短的名称,并且由于容器名称始终限定在它们出现的特定 pod 范围内,因此在此处使用简短的固定名称没有任何问题

spec:
containers:
- name: container

关于kubernetes-helm - 为什么 helm 不使用部署模板中定义的名称?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53387144/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com