您可以通过以下两种方法使用 Buildpack 构建容器映像:
- 使用 packCLI 在本地构建,以便在本地测试您的函数并在部署前快速对更改进行原型设计。
- 使用 Cloud Build 远程构建。使用 Cloud Build 进行构建适合具有资源密集型构建流程的函数,还有助于保护您的软件供应链。
配置项目以构建函数
如需使用 Buildpack 构建函数,请执行以下操作:
- 添加 Functions 框架库。 
- 将 - GOOGLE_FUNCTION_TARGET环境变量设置为用作入口点的函数的名称。为此,您可以在源代码所在的文件夹中添加- project.toml。- project.toml文件必须具有以下配置:
[[build.env]]
    name = "GOOGLE_FUNCTION_TARGET"
    value =  "ENTRY_POINT"
将 ENTRY_POINT 替换为函数方法。
如需详细了解如何将环境变量与 Cloud Run functions 搭配使用,请参阅配置 Cloud Run functions 服务。
本地构建
Pack 是由 CNB 项目维护的 CLI 工具,用于为 Buildpack 的使用提供支持。使用 pack CLI 可在本地将函数构建到容器映像中。
准备工作
- 在工作站上安装 Docker 社区版 (CE)。pack会将 Docker 用作 OCI 映像构建器。
- 安装 Pack CLI。
- 安装 Git 源代码控制工具以从 GitHub 获取示例应用。
在本地构建函数
您可以使用 pack build 命令并指定默认构建器 --builder=gcr.io/buildpacks/builder,以在本地构建容器映像。
pack build --builder=gcr.io/buildpacks/builder IMAGE_NAME
将 IMAGE_NAME 替换为容器映像的名称。
您还可以通过扩展构建来自定义容器映像并运行映像。
在本地构建示例函数
以下示例演示了如何在本地构建示例。
- 将示例代码库克隆到本地计算机:
    git clone https://github.com/GoogleCloudPlatform/buildpack-samples.git 
- 切换到包含应用示例代码的目录:Gocd buildpack-samples/sample-functions-framework-go Javacd buildpack-samples/sample-functions-framework-java-mvn Node.jscd buildpack-samples/sample-functions-framework-node Pythoncd buildpack-samples/sample-functions-framework-python Rubycd buildpack-samples/sample-functions-framework-ruby 
- 使用 pack构建示例函数:Gopack build --builder=gcr.io/buildpacks/builder sample-functions-framework-go Javapack build --builder gcr.io/buildpacks/builder:v1 sample-functions-java-mvn Node.jspack build --builder=gcr.io/buildpacks/builder sample-functions-framework-node Pythonpack build --builder=gcr.io/buildpacks/builder sample-functions-framework-python Rubypack build --builder=gcr.io/buildpacks/builder sample-functions-framework-ruby 
- 使用 docker运行映像:Godocker run -p8080:8080 sample-functions-framework-go Javadocker run -it -ePORT=8080 -p8080:8080 sample-functions-java-mvn Node.jsdocker run -it -ePORT=8080 -p8080:8080 sample-functions-framework-node Pythondocker run -it -ePORT=8080 -p8080:8080 sample-functions-framework-python Rubydocker run -it -ePORT=8080 -p8080:8080 sample-functions-framework-ruby 
- 通过浏览到 localhost:8080 来访问正在运行的函数。
远程构建
使用 Cloud Build 可将函数构建到容器映像中,并使用 Artifact Registry 作为存储和部署每个映像的容器仓库。
准备工作
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
    
    
      
        In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Cloud Build and Artifact Registry APIs. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
      Install the Google Cloud CLI. 
- 
          如果您使用的是外部身份提供方 (IdP),则必须先使用联合身份登录 gcloud CLI。 
- 
        如需初始化 gcloud CLI,请运行以下命令: gcloud init
- 
    
    
      
        In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the Cloud Build and Artifact Registry APIs. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
      Install the Google Cloud CLI. 
- 
          如果您使用的是外部身份提供方 (IdP),则必须先使用联合身份登录 gcloud CLI。 
- 
        如需初始化 gcloud CLI,请运行以下命令: gcloud init
- 确保 Google Cloud 项目有权访问容器映像仓库。
  如需配置对 Artifact Registry 中的 Docker 仓库的访问权限,请执行以下操作: - 在 Google Cloud 项目的同一位置创建新的 Docker 代码库。
gcloud artifacts repositories create REPO_NAME \ --repository-format=docker \ --location=REGION --description="DESCRIPTION" - 将 REPO_NAME替换为您为 Docker 仓库选择的名称。
- 将 REGION替换为 Google Cloud 项目的位置或最接近该位置的位置。
- 将 DESCRIPTION替换为您选择的说明。
 例如,如需在 us-west2中创建具有说明“Docker 仓库”的docker仓库,请运行以下命令:gcloud artifacts repositories create buildpacks-docker-repo --repository-format=docker \ --location=us-west2 --description="Docker repository" 
- 将 
- 验证您的代码库已创建:
gcloud artifacts repositories list 您应该会在列表中看到您为 Docker 仓库选择的名称。 
 
- 在 Google Cloud 项目的同一位置创建新的 Docker 代码库。
- 将 LOCATION替换为容器仓库的区域名称,例如us-west2
- 将PROJECT_ID替换为 Google Cloud 项目的 ID。
- 将 REPO_NAME替换为 Docker 仓库的名称。
- 将 IMAGE_NAME替换为容器映像的名称。
- 创建一个名为 cloudbuild.yaml的 YAML 文件,其中包含容器映像仓库的 URI。
- 将 LOCATION替换为容器仓库的区域名称,例如us-west2。
- 将PROJECT_ID替换为 Google Cloud 项目的 ID。
- 将 REPO_NAME替换为 Docker 仓库的名称。
- 将 IMAGE_NAME替换为容器映像的名称。
- 构建应用。 - 如果您将配置文件命名为 - cloudbuild.yaml,则可以运行以下命令:- gcloud builds submit .
- 将示例代码库克隆到本地计算机:
    git clone https://github.com/GoogleCloudPlatform/buildpack-samples.git 
- 切换到包含应用示例代码的目录:Gocd buildpack-samples/sample-functions-framework-go Javacd buildpack-samples/sample-functions-framework-java-mvn Node.jscd buildpack-samples/sample-functions-framework-node Pythoncd buildpack-samples/sample-functions-framework-python Rubycd buildpack-samples/sample-functions-framework-ruby 
- 使用 gcloud将应用源代码提交到 Cloud Build:Gogcloud builds submit --pack image=LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/sample-functions-framework-go Javagcloud builds submit --pack image=LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/sample-functions-framework-gradle Node.jsgcloud builds submit --pack image=LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/sample-functions-framework-node Pythongcloud builds submit --pack image=LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/sample-functions-framework-python Rubygcloud builds submit --pack image=LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/sample-functions-framework-ruby 您需要进行如下替换: - 将 LOCATION替换为容器仓库的区域名称。示例:us-west2-docker.pkg.dev
- 将PROJECT_ID替换为 Google Cloud 项目的 ID。
- 将 REPO_NAME替换为 Docker 仓库的名称。
 
- 将 
- 
    验证示例函数是否已成功发布到 REPO_NAME:gcloud artifacts docker images list LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME 您需要进行如下替换: - 将 LOCATION替换为容器仓库的区域名称,例如us-west2。
- 将PROJECT_ID替换为 Google Cloud 项目的 ID。
- 将 REPO_NAME替换为 Docker 仓库的名称。
 
- 将 
- 将函数映像部署到 Cloud Run。
- 设置环境变量。
- 配置构建映像。
- 使用缓存映像加速构建。
远程构建函数
您可以使用 gcloud builds submit 命令构建容器映像并将其上传到仓库。
您可以选择在命令本身中指定容器映像或是使用配置文件。
使用命令进行构建
如需在不使用配置文件的情况下进行构建,请指定 image 标志:
gcloud builds submit --pack image=LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/IMAGE_NAME
您需要进行如下替换:
示例:
gcloud builds submit --pack image=us-west2-docker.pkg.dev/my-project-id/my-buildpacks-docker-repo
使用配置文件进行构建
您可以使用配置文件来定义映像仓库配置详细信息,以便仅包含构建命令。配置文件使用 YAML 文件格式,并且必须包含使用 pack CLI 的构建步骤。
options: logging: CLOUD_LOGGING_ONLY pool: {} projectId: PROJECT_ID steps: - name: gcr.io/k8s-skaffold/pack entrypoint: pack args: - build - LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/IMAGE_NAME - --builder - gcr.io/buildpacks/builder:latest - --network - cloudbuild images: - LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/IMAGE_NAME
您需要进行如下替换:
示例:远程构建示例函数
以下示例演示了如何远程构建示例,并验证容器映像是否已推送到 Artifact Registry 中的仓库。