Helm 部署缺少 Skaffold 调试 JAVA_TOOL_OPTIONS
Skaffold debug is missing JAVA_TOOL_OPTIONS with Helm deployment
如果我正确理解此处的文档...
如果我尝试 运行 使用 'skaffold debug' 或使用 IntelliJ 'Develop on Kubernetes' 和调试的 K8s 项目,skaffold 必须在我的 k8s deployment/service 文件中插入用于 jdwp 和JAVA_TOOL_OPTIONS 的环境变量。这对我来说没有发生。
我正在使用 Helm Chart 来部署我的 k8s 工件,但我没有看到任何地方配置了这些东西(正如它在此处 GitHub Issue 中提到的)。
如果我手动配置我的 deployment\service yamls,为 jdwp 插入端口 5005,为 jdwp 插入环境变量 JAVA_TOOL_OPTIONS 和端口转发 5005,那么我可以远程附加到进程和调试,但是 skaffold 是无法自行管理它(它甚至没有尝试,我在日志中看不到 JAVA_TOOL_OPTIONS)。
可能,它不理解我正在 运行 一个 JVM 项目,或者可能是,当我用我的 Helm 项目创建 'helm create' 并且有几个 yaml 文件(configmap.yaml、deployment.yaml、hpa.yaml、ingress.yaml、service.yaml、serviceaccount.yaml) 无法找到要操作的正确文件。
如果我也理解正确的话,要调试的deployment/pod必须有如下注解:
debug.cloud.google.com/config
完全没有,我在部署时看到的只有以下内容 -
ide: idea
ideVersion: 2021.1.1.0.0
ijPluginVersion: unknown
skaffold.dev/run-id: d2420cca-f212-4349-b078-41f36ed51bd5
知道这里出了什么问题吗?
实际上,部署运行正常,我的 Pod 报告准备就绪检查正常,但从 skaffold/intellij 开始没有调试。
@posthumecaver 的 Helm 图表与 skaffold.yaml
之间存在一些不匹配,导致 Skaffold 无法配置映像。我将在这里总结调查结果,以帮助那些偶然发现此问题的人 post.
@posthumecaver 正在使用 Skaffold 的 Helm 支持。这要求 skaffold.yaml
和 Helm 图表使用公共键来引用图像。 Helm 中使用了三种方法来引用图像:
完全限定名称(默认)
Skaffold 将配置 Helm,为完全标记的图像引用设置一个密钥。
skaffold.yaml
设置:
build:
artifacts:
- image: gcr.io/my-project/my-image
deploy:
helm:
releases:
- name: my-chart
chartPath: helm
artifactOverrides:
img: gcr.io/my-project/my-image
图表模板:
image: "{{.Values.img}}"
values.yaml
(注意 Skaffold 会覆盖这个值):
img: gcr.io/other-project/other-image:latest
Skaffold 将调用
helm install <chart> <chart-path> --set-string img=gcr.io/my-project/my-image:generatedTag@sha256:digest
拆分存储库和标签
Skaffold 可以配置为为 Helm 提供单独的存储库和标签。 artifactOverrides
中使用的密钥用作生成两个密钥 {key}.repository
和 {key}.tag
.
的基础部分
skaffold.yaml
设置:
build:
artifacts:
- image: gcr.io/my-project/my-image
deploy:
helm:
releases:
- name: my-chart
chartPath: helm
artifactOverrides:
img: gcr.io/my-project/my-image
imageStrategy:
helm: {}
图表模板:
image: "{{.Values.img.repository}}:{{.Values.img.tag}}"
values.yaml
(注意 Skaffold 会覆盖这些值):
img:
repository: gcr.io/other-project/other-image
tag: latest
Skaffold 将调用
helm install <chart> <chart-path> --set-string img.repository=gcr.io/my-project/my-image,img.tag=generatedTag@sha256:digest
拆分注册表、存储库和标记
Skaffold 也可以配置为为 Helm 提供单独的存储库和标签。 artifactOverrides
中使用的密钥用作生成三个密钥的基础部分:{key}.registry
、{key}.repository
和 {key}.tag
。
skaffold.yaml
设置:
build:
artifacts:
- image: gcr.io/my-project/my-image
deploy:
helm:
releases:
- name: my-chart
chartPath: helm
artifactOverrides:
img: gcr.io/my-project/my-image
imageStrategy:
helm:
explicitRegistry: true
图表模板:
image: "{{.Values.img.registry}}/{{.Values.img.repository}}:{{.Values.img.tag}}"
values.yaml
(注意 Skaffold 会覆盖这些值):
img:
registry: gcr.io
repository: other-project/other-image
tag: latest
Skaffold 将调用
helm install <chart> <chart-path> --set-string img.registry=gcr.io,img.repository=my-project/my-image,img.tag=generatedTag@sha256:digest
如果我正确理解此处的文档...
如果我尝试 运行 使用 'skaffold debug' 或使用 IntelliJ 'Develop on Kubernetes' 和调试的 K8s 项目,skaffold 必须在我的 k8s deployment/service 文件中插入用于 jdwp 和JAVA_TOOL_OPTIONS 的环境变量。这对我来说没有发生。
我正在使用 Helm Chart 来部署我的 k8s 工件,但我没有看到任何地方配置了这些东西(正如它在此处 GitHub Issue 中提到的)。
如果我手动配置我的 deployment\service yamls,为 jdwp 插入端口 5005,为 jdwp 插入环境变量 JAVA_TOOL_OPTIONS 和端口转发 5005,那么我可以远程附加到进程和调试,但是 skaffold 是无法自行管理它(它甚至没有尝试,我在日志中看不到 JAVA_TOOL_OPTIONS)。
可能,它不理解我正在 运行 一个 JVM 项目,或者可能是,当我用我的 Helm 项目创建 'helm create' 并且有几个 yaml 文件(configmap.yaml、deployment.yaml、hpa.yaml、ingress.yaml、service.yaml、serviceaccount.yaml) 无法找到要操作的正确文件。
如果我也理解正确的话,要调试的deployment/pod必须有如下注解:
debug.cloud.google.com/config
完全没有,我在部署时看到的只有以下内容 -
ide: idea
ideVersion: 2021.1.1.0.0
ijPluginVersion: unknown
skaffold.dev/run-id: d2420cca-f212-4349-b078-41f36ed51bd5
知道这里出了什么问题吗?
实际上,部署运行正常,我的 Pod 报告准备就绪检查正常,但从 skaffold/intellij 开始没有调试。
@posthumecaver 的 Helm 图表与 skaffold.yaml
之间存在一些不匹配,导致 Skaffold 无法配置映像。我将在这里总结调查结果,以帮助那些偶然发现此问题的人 post.
@posthumecaver 正在使用 Skaffold 的 Helm 支持。这要求 skaffold.yaml
和 Helm 图表使用公共键来引用图像。 Helm 中使用了三种方法来引用图像:
完全限定名称(默认)
Skaffold 将配置 Helm,为完全标记的图像引用设置一个密钥。
skaffold.yaml
设置:
build:
artifacts:
- image: gcr.io/my-project/my-image
deploy:
helm:
releases:
- name: my-chart
chartPath: helm
artifactOverrides:
img: gcr.io/my-project/my-image
图表模板:
image: "{{.Values.img}}"
values.yaml
(注意 Skaffold 会覆盖这个值):
img: gcr.io/other-project/other-image:latest
Skaffold 将调用
helm install <chart> <chart-path> --set-string img=gcr.io/my-project/my-image:generatedTag@sha256:digest
拆分存储库和标签
Skaffold 可以配置为为 Helm 提供单独的存储库和标签。 artifactOverrides
中使用的密钥用作生成两个密钥 {key}.repository
和 {key}.tag
.
skaffold.yaml
设置:
build:
artifacts:
- image: gcr.io/my-project/my-image
deploy:
helm:
releases:
- name: my-chart
chartPath: helm
artifactOverrides:
img: gcr.io/my-project/my-image
imageStrategy:
helm: {}
图表模板:
image: "{{.Values.img.repository}}:{{.Values.img.tag}}"
values.yaml
(注意 Skaffold 会覆盖这些值):
img:
repository: gcr.io/other-project/other-image
tag: latest
Skaffold 将调用
helm install <chart> <chart-path> --set-string img.repository=gcr.io/my-project/my-image,img.tag=generatedTag@sha256:digest
拆分注册表、存储库和标记
Skaffold 也可以配置为为 Helm 提供单独的存储库和标签。 artifactOverrides
中使用的密钥用作生成三个密钥的基础部分:{key}.registry
、{key}.repository
和 {key}.tag
。
skaffold.yaml
设置:
build:
artifacts:
- image: gcr.io/my-project/my-image
deploy:
helm:
releases:
- name: my-chart
chartPath: helm
artifactOverrides:
img: gcr.io/my-project/my-image
imageStrategy:
helm:
explicitRegistry: true
图表模板:
image: "{{.Values.img.registry}}/{{.Values.img.repository}}:{{.Values.img.tag}}"
values.yaml
(注意 Skaffold 会覆盖这些值):
img:
registry: gcr.io
repository: other-project/other-image
tag: latest
Skaffold 将调用
helm install <chart> <chart-path> --set-string img.registry=gcr.io,img.repository=my-project/my-image,img.tag=generatedTag@sha256:digest