0

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

支架调试

如果我尝试使用“skaffold debug”或 IntelliJ“在 Kubernetes 上开发”和 Debug 运行 K8s 项目,skaffold 必须在我的 k8s 部署/服务文件中插入额外的 jdwp 端口和带有 JAVA_TOOL_OPTIONS 的环境变量。这对我来说没有发生。

我正在使用 Helm Chart 来部署我的 k8s 工件,但我看不到任何配置这些东西的地方(正如它在GitHub Issue中也提到的那样)。

如果我手动配置我的部署\服务 yamls,为 jdwp 插入端口 5005,为 jdwp 插入环境变量 JAVA_TOOL_OPTIONS 和端口转发 5005,那么我可以远程附加到进程和调试,但 skaffold 无法自行管理它(它不是即使尝试,我的日志中也没有看到 JAVA_TOOL_OPTIONS)。

可能是,它不明白我正在运行一个 JVM 项目,或者可能是,而我使用“helm create”创建了我的 Helm 项目并且有几个 yaml 文件(configmap.yaml、deployment.yaml、hpa.yaml、ingress .yaml、service.yaml、serviceaccount.yaml)它无法找到正确的文件进行操作。

如果我也理解正确,将被调试的部署/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 开始没有调试。

4

1 回答 1

1

@posthumecaver 的 Helm 图表与skaffold.yaml阻止 Skaffold 配置图像的图表之间存在一些不匹配。我将在这里总结这些发现,以帮助那些偶然发现这篇文章的人。

@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
于 2021-06-15T14:36:22.830 回答