Helm 部署缺少 Skaffold 调试 JAVA_TOOL_OPTIONS

Skaffold debug is missing JAVA_TOOL_OPTIONS with Helm deployment

如果我正确理解此处的文档...

Skaffold Debug

如果我尝试 运行 使用 '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必须有如下注解:

Annotations

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