使用 Functions 模拟器运行函数

借助 Google Cloud CLI Functions 模拟器,您可以通过 gcloud alpha functions local 命令管理 Cloud Run functions 函数的本地实例。这样,您可以先在本地系统上部署和测试函数,然后再将其部署到Google Cloud 环境。

Functions 模拟器使用 Google Cloud 的 Buildpack 将函数代码打包为可在本地运行的容器映像。然后,您可以使用 Docker 在本地运行这些映像。

安装前提条件

在继续操作之前,请确保您已安装以下各项:

在本地部署函数

如需使用 Functions 模拟器在本地部署函数,请使用 gcloud functions 命令:

Node.js

  gcloud alpha functions local deploy LOCAL_DEPLOYMENT_NAME \
    --entry-point=ENTRY_POINT \
    --no-gen2 \
    --runtime=nodejs20

Python

  gcloud alpha functions local deploy LOCAL_DEPLOYMENT_NAME \
    --entry-point=ENTRY_POINT \
    --runtime=python312

Go

  gcloud alpha functions local deploy LOCAL_DEPLOYMENT_NAME \
    --entry-point=ENTRY_POINT \
    --no-gen2 \
    --runtime=go119

Java

  gcloud alpha functions local deploy LOCAL_DEPLOYMENT_NAME \
    --entry-point=ENTRY_POINT \
    --no-gen2 \
    --runtime=java17 

C#

  gcloud alpha functions local deploy LOCAL_DEPLOYMENT_NAME \
    --entry-point=ENTRY_POINT \
    --no-gen2 \
    --runtime=dotnet6

Ruby

  gcloud alpha functions local deploy LOCAL_DEPLOYMENT_NAME \
    --entry-point=ENTRY_POINT \
    --runtime=ruby33

PHP

  gcloud alpha functions local deploy LOCAL_DEPLOYMENT_NAME \
    --entry-point=ENTRY_POINT \
    --no-gen2 \
    --runtime=php82

您需要进行如下替换:

  • LOCAL_DEPLOYMENT_NAME:用于在本地部署函数的名称。
  • ENTRY_POINT:函数的入口点。

您可以使用以下可选标志进一步配置部署命令:

标志 说明
--port 用于监听请求的端口(默认值:8080)。
--builder 要使用的 Buildpack 构建器的名称

--builder 值默认为函数语言的 App Engine 构建器。例如,对于 Python,默认为 gcr.io/serverless-runtimes/google-22-full/builder/python

首次使用 gcloud alpha 命令时,gcloud 命令会提示您安装 gcloud alpha 命令集。

调用本地函数

如需在不使用数据的情况下调用本地函数,请使用以下命令:

gcloud alpha functions local call LOCAL_DEPLOYMENT_NAME

LOCAL_DEPLOYMENT_NAME 替换为您要用于在本地部署函数的名称。

如需在对本地函数的调用中包含数据,请选择与您的函数类型匹配的标签页:

HTTP 函数

按如下所示调用本地 HTTP 函数:

gcloud alpha functions local call LOCAL_DEPLOYMENT_NAME \
    --data='{"message": "MESSAGE"}'

您需要进行如下替换:

  • LOCAL_DEPLOYMENT_NAME:用于在本地函数部署的名称。
  • ENTRY_POINT:函数的入口点。
  • MESSAGE:要作为 HTTP 请求正文传入的文本字符串。

CloudEvent 函数

如需调用本地 CloudEvent 函数,您必须提供一个 CloudEvent JSON 对象,用于描述触发器事件:

gcloud alpha functions local call LOCAL_DEPLOYMENT_NAME \
    --cloud-event="CLOUD_EVENT_JSON"

您需要进行如下替换:

  • LOCAL_DEPLOYMENT_NAME:用于在本地函数部署的名称。
  • ENTRY_POINT:函数的入口点。
  • CLOUD_EVENT_JSON:结构化内容模式下的 JSON 编码字符串,用于描述触发事件。如需了解详情和示例,请参阅 CloudEvent - JSON 事件格式

以下是一个命令行示例:

gcloud alpha functions local call my-function --cloud-event='{
 "specversion" : "1.0",
  "type" : "com.github.pull.create",
  "source" : "https://github.com/cloudevents/spec/pull",
  "subject" : "123",
  "id" : "ce",
  "time" : "2021-01-27T18:30:00Z", "data" : "{\n \"subscription\": \"projects\/test-project\/subscriptions\/my-subscription\",\n \"message\": {\n \"attributes\": {\n \"attr1\":\"attr1-value\"\n },\n \"data\": \"d29ybGQ=\",\n \"messageId\": \"message-id\",\n \"publishTime\":\"2021-02-05T04:06:14.109Z\",\n \"orderingKey\": \"ordering-key\"\n }\n}"
  }'

如需详细了解如何为 CloudEvent 定义 JSON 格式,请参阅 CloudEvent 规范

删除本地函数部署

使用以下命令删除本地函数部署:

gcloud alpha functions local delete LOCAL_DEPLOYMENT_NAME

LOCAL_DEPLOYMENT_NAME 替换为用于在本地函数部署的名称。

此命令会取消部署函数,但不会删除函数代码。

后续步骤