Google Cloud Debugger 找不到部署为 Cloud Run 服务的 Spring Boot Web 应用程序

问题描述

我按照指南 (https://cloud.google.com/debugger/docs/setup/java#cloud-run) 为我的云运行服务设置了云调试器。一切看起来都应该有效。但是调试器 UI 告诉我它找不到任何应用程序。

enter image description here

但是我做了文档中提到的所有事情

  • 代码位于代码
  • Cloud Build 在 master 推送时触发
  • 我下载了 cdbg-java-agent.so
  • 我使用 -agentpath 选项运行 Java 应用程序
  • 正在通过 cloudbuild.yaml
  • 部署 Cloud Run 服务
  • Cloud Run 服务正常启动并运行

但是,正如您在屏幕截图中看到的那样,部署成功后无法找到我的应用程序。

以下是我的配置的一些详细信息:

  • Spring Boot v2.4.2
  • 科特林 1.4.21

这是我的 Dockerfile

FROM gradle:6.7.0-jdk14 as build
USER root
workdir /dist
ADD . /dist
RUN gradle assemble

FROM alpine as agent
USER root
workdir /agent
RUN wget -qO- https://storage.googleapis.com/cloud-debugger/compute-java/debian-wheezy/cdbg_java_agent_gce.tar.gz | tar xvz

FROM openjdk:14-slim
workdir /app
copY --from=agent /agent/cdbg_java_agent.so agent.so
copY --from=build /dist/build/libs/user-service.jar app.jar
EXPOSE 8080
CMD ["java","-agentpath:/app/agent.so","-Dcom.google.cdbg.breakpoints.enable_canary=false","-jar","app.jar"]

这里是 docker 构建输出

deploying '<unkNown> Dockerfile: Dockerfile'...
Building image...
Preparing build context archive...
[==================================================>]1855/1855 files
Done

Sending build context to Docker daemon...
[==================================================>] 76.19MB
Done

Step 1/15 : FROM gradle:6.7.0-jdk14 as build
 ---> 5af4d25725b2
Step 2/15 : USER root
 ---> Using cache
 ---> c97e9145e3e1
Step 3/15 : workdir /dist
 ---> Using cache
 ---> 468fff36a2e7
Step 4/15 : ADD . /dist
 ---> c435bd2ffde9
Step 5/15 : RUN gradle assemble
 ---> Running in 70f5c69b7dde

Welcome to Gradle 6.7!

Here are the highlights of this release:
 - File system watching is ready for production use
 - Declare the version of Java your build requires
 - Java 15 support

For more details see https://docs.gradle.org/6.7/release-notes.html

Starting a Gradle Daemon (subsequent builds will be faster)
> Task :compileKotlin
> Task :compileJava NO-SOURCE
> Task :processResources
> Task :classes
> Task :bootJarMainClassName
> Task :bootJar
> Task :inspectClassesForKotlinIC
> Task :jar SKIPPED
> Task :assemble

Deprecated Gradle features were used in this build,making it incompatible with Gradle 7.0.
Use '--warning-mode all' to show the individual deprecation warnings.
See https://docs.gradle.org/6.7/userguide/command_line_interface.html#sec:command_line_warnings

BUILD SUCCESSFUL in 1m 48s
5 actionable tasks: 5 executed
Removing intermediate container 70f5c69b7dde
 ---> 5bbd9485f873

Step 6/15 : FROM alpine as agent
 ---> 28f6e2705743
Step 7/15 : USER root
 ---> Using cache
 ---> 4a0572e8ff4a
Step 8/15 : workdir /agent
 ---> Using cache
 ---> 0374735af05d
Step 9/15 : RUN wget -qO- https://storage.googleapis.com/cloud-debugger/compute-java/debian-wheezy/cdbg_java_agent_gce.tar.gz | tar xvz
 ---> Using cache
 ---> ef141a7d5acc

Step 10/15 : FROM openjdk:14-slim
 ---> 38fca30874ab
Step 11/15 : workdir /app
 ---> Using cache
 ---> 4dd576d38d65
Step 12/15 : copY --from=agent /agent/cdbg_java_agent.so agent.so
 ---> Using cache
 ---> ff5fc93d2d5e
Step 13/15 : copY --from=build /dist/build/libs/user-service.jar app.jar
 ---> 4b009124345f
Step 14/15 : EXPOSE 8080
 ---> Running in 99f71fb86534
Removing intermediate container 99f71fb86534
 ---> 38fcd9d00999
Step 15/15 : CMD ["java","app.jar"]
 ---> Running in 309f35aed48f
Removing intermediate container 309f35aed48f
 ---> 43757d33b2ee

Successfully built 43757d33b2ee
Existing container found: 94d3fab4505461e8e694b61909ba1f7d827d8f7078b4dd8d1d36d4c4e0a0ac08,removing...
Creating container...
Container Id: b99675b5f6c00a0e5bec76999db04abf92eab29d257ee887bcea123a02789850
Container name: '/quirky_stonebraker'
Attaching to container '/quirky_stonebraker'...
Starting container '/quirky_stonebraker'
'<unkNown> Dockerfile: Dockerfile' has been deployed successfully.

容器运行良好,如上述部署的云运行服务所述。 所以我不知道该怎么做才能完成这项工作。我希望有人能在这里帮助我


如果相关,我还会添加我的 cloudbuild.yaml

steps:
  - name: 'gradle:6.8.3-jdk11'
    entrypoint: 'gradle'
    args: [ 'check','-x','test']
  - name: 'gradle:6.8.3-jdk11'
    entrypoint: 'gradle'
    args: [ 'test']
  - name: 'gradle:6.8.3-jdk11'
    entrypoint: 'gradle'
    args: [ 'integration-test']
  - name: 'gcr.io/cloud-builders/docker'
    args: [ 'build','-t','eu.gcr.io/$PROJECT_ID/user-service:$BUILD_ID','.' ]
  - name: 'gcr.io/cloud-builders/docker'
    args: [ 'push','eu.gcr.io/$PROJECT_ID/user-service:$BUILD_ID' ]
  - name: 'gcr.io/google.com/cloudsdktool/cloud-sdk'
    entrypoint: gcloud
    args:
      - 'alpha'
      - 'run'
      - 'deploy'
      - 'user-service'
      - '--image=eu.gcr.io/$PROJECT_ID/user-service:$BUILD_ID'
      - '--concurrency=10'
      - '--cpu=1'
      - '--memory=512Mi'
      - '--region=europe-west3'
      - '--max-instances=2'
      - '--platform=managed'
      - '--port=8080'
      - '--timeout=3000'
      - '--set-env-vars=sql_CONNECTION=10.28.96.3,sql_USER=test,sql_PASSWORD=test'
      - '--set-env-vars=AUTH0_DOMAIN=prototype.eu.auth0.com,AUTH0_CLIENT_ID=123,AUTH0_CLIENT_SECRET=123'
      - '--set-env-vars=^#^SPRING_PROFILES_ACTIVE=prod'
      - '--allow-unauthenticated'
      - '--ingress=internal'
      - '--vpc-connector=cloud-run'
      - '--vpc-egress=private-ranges-only'
      - '--set-cloudsql-instances=$PROJECT_ID:europe-west1:prototype'

images:
  - 'eu.gcr.io/$PROJECT_ID/user-service:$BUILD_ID'
timeout: 3000s

解决方法

如果您查看压缩的代理文件中的内容,您会注意到其中有几个文件名为:

  1. cdbg_java_agent.so
  2. cdbg_java_agent_internals.jar
  3. version.txt

您遇到这个问题是因为您没有将 internals.jar 文件复制到 /app 目录。共享对象文件具有依赖性,这可以解释为什么指示用户为调试器创建单独的目录。

要在这种情况下修复它,请将丢失的文件添加到您的 Dockerfile 中,如下所示:

COPY --from=agent /agent/cdbg_java_agent.so agent.so
COPY --from=agent /agent/cdbg_java_agent_internals.jar cdbg_java_agent_internals.jar
COPY --from=build /dist/build/libs/user-service.jar app.jar

然后等待大约。大约 5 分钟,直到您的服务出现在调试器上。请注意,源代码不会出现 automatically,除非它位于 Git 存储库中。为此,您必须select the source code manually

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...