使用 Cloud Code for Cloud Shell 在本地开发 Cloud Run 服务

将服务部署到 Cloud Run 之前,您可以使用 Cloud Run 模拟器在本地开发该服务。

配置服务以进行开发

如果您未定义 .vscode/launch.json 文件,则可以使用 Run/Debug on Cloud Run Emulator 对话框配置启动,然后将设置保存到 .vscode/launch.json。如果您已配置 .vscode/launch.json 文件,则可以直接修改该文件。

如需在本地运行服务,请指定配置:

  1. 打开 Command Palette(按 Ctrl/Cmd+Shift+P 或点击 View > Command Palette),然后运行 Run on Cloud Run Emulator 命令。
  2. 在“在 Cloud Run 模拟器上运行/调试”(Run/Debug on Cloud Run Emulator) 对话框中,为您的配置设置规范:

    • 只有本地安装的构建工具适用于 Cloud Run 模拟器
    • 选择 DockerBuildpack 作为构建器,然后指定来源
    • (可选)指定要传递给正在运行的 容器,展开 Advanced Build Settings(高级构建设置),然后点击以指定 键值对。
      名称 说明 示例
      PORT HTTP 服务器监听的端口。 8080
      K_SERVICE 正在运行的 Cloud Run 服务的名称。 hello-world
      K_REVISION 正在运行的 Cloud Run 修订版本的名称。 hello-world.1
      K_CONFIGURATION 创建了该修订版本的 Cloud Run 配置的名称。 hello-world
    • (可选)如需指定 Cloud SQL 连接,请展开高级服务设置,点击连接,然后每行指定一个 Cloud SQL 连接。
    • (可选)选中 让用户可从本地网络中的其他设备访问该服务 选项。
    • (可选)如果您只想在进行更改时手动重新构建和运行服务,而不是自动执行此操作,请取消选中自动重建并重新运行更改选项。

在本地运行服务

  1. 定义首选设置后,通过点击运行运行服务。

  2. 输出窗口中监控部署的状态。

    部署完成后,您可以通过打开输出窗口中显示的网址来查看正在运行的服务。

  3. 如需查看详细日志,请在输出窗口中切换到详细的 Cloud Run 视图。

    输出窗格,已从输出渠道下拉菜单中选择“hello-world-5 - Detailed”

  4. 会话完成后,右键点击即可使用以下命令:

    • 查看日志:使用 Cloud Code Logs Explorer。
    • 打开网址:打开特定应用服务的网址 服务。
  5. 如果您在启动配置中关闭了监视模式,并且您希望更改应用并重新构建和重新部署应用,请点击 Cloud Code 状态栏,然后点击开启监视模式

  6. 要停止部署,您可以在当前部署的操作栏中点击停止按钮。

    Cloud Run 部署的操作栏

存储密文

如果您的代码包含潜在的敏感数据,例如 API 密钥、密码和证书,将它们存储为密文有助于保护这些数据。通过 借助 Cloud Code Secret Manager 集成 存储这些 Secret 并以程序化方式提取它们。如需详细了解如何 您可以使用 Cloud Code 创建和管理 Secret,请参阅 Secret Manager 指南

自定义现有 launch.json 配置

Cloud Code 插件会更新 launch.json 配置文件 。如需进一步自定义服务的运行方式,您可以在 .vscode/launch.json 文件中指定以下字段:

  • watch:监控工作区中的更改并重新运行服务。默认情况下为 true。

    以下示例显示了将手表设置为 true

    "watch": true,
    
  • build:指定构建器 (Docker、 jibMaven、jibGradle 或 buildpack) 构建映像时要使用的工具

    以下示例展示了 Docker 构建器:

    "build": {
      "docker": {
        "path": "Dockerfile"
      }
    },
    

    以下示例展示了 Buildpack 构建器:

    "build": {
      "buildpacks": {
        "path": "src/requirements.txt",
        "builder": "gcr.io/buildpacks/builder:v1"
      }
    },
    
  • image:指定要使用的映像的名称。

    以下示例展示了如何指定映像名称:

      "image": "hello-world",
    
  • service:指定要使用的 Cloud Run 服务。

    以下示例展示了如何指定服务名称、端口和资源限制:

    "service": {
      "name": "hello-world",
      "containerPort": 8080,
      "resources": {
        "limits": {
          "memory": "256Mi"
        }
      }
    },
    
  • debug:指定调试设置,例如远程路径映射以映射本地 指向远程容器上的某个路径的路径。

    以下示例展示了一个调试部分,该部分指示源文件的 地点:

    "debug": {
      "sourceFileMap": {
        "${workspaceFolder}": "/app"
      }
    }