Cloud Run supports directly deploying functions, however, you can also build your function into a container image using Google Cloud's buildpacks and then deploy this container image to Cloud Run.
Common use cases for building functions into container include:
- Continuous Integration and Delivery: Developers author and push function code to a source repository, a CI/CD system automatically builds the function into a container, runs tests, and automatically deploys it to a staging environment.
- Infrastructure as Code: Cloud Run resources that are managed using YAML or Terraform reference a container image URL. The function code written by developers need to be built into a container image.
This page details how you can replicate the exact build process of Cloud Run functions using two ways:
- Using packCLI
- Using Cloud Build as the remote build system
Function entry point
To build functions with buildpacks:
- Include the Functions Framework library. 
- Set the - GOOGLE_FUNCTION_TARGETenvironment variable to the name of the function that you use as the entrypoint. You can do this by including a- project.tomlin the same folder as your source code. The- project.tomlfile must have the following configuration:
[[build.env]]
    name = "GOOGLE_FUNCTION_TARGET"
    value =  "ENTRY_POINT"
Replace ENTRY_POINT with the function method.
For details about how to use environment variables with Cloud Run functions, see Configure Cloud Run functions services.
Builders
Cloud Run functions are built on top of base images maintained and published under Google Cloud's buildpacks.
Builders are images that consist of buildpacks and operating system packages (also known as Stacks). Builders are used to convert your function's source code into a running container.
You can choose from the list of supported Google Cloud's buildpacks builders.
Building with pack
Pack
is a CLI tool maintained by the CNB project to support the use of buildpacks. Use
the pack CLI to locally build your functions into a container image.
Before you begin
- Install Docker Community Edition (CE) 
on your workstation. Docker is used by packas an OCI image builder.
- Install Pack CLI.
- Install the Git source control tool to fetch the sample application from GitHub.
Build a function locally
You use the pack build command and specify the default builder
--builder=gcr.io/buildpacks/builder to build your container images locally.
pack build --builder=gcr.io/buildpacks/builder IMAGE_NAME
Replace IMAGE_NAME with the name of your container image.
You can also customize your container image by extending the build and run images.
Build a sample function locally
The following examples demonstrate how to build a sample locally.
- Clone the sample repository to your local machine:
    git clone https://github.com/GoogleCloudPlatform/buildpack-samples.git 
- Change to the directory that contains the application sample code:
    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 
- Use packto build the sample function: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 
- Run the image using 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 
- Visit the running function by browsing to localhost:8080.
Building with a remote build system
Use Cloud Build to build your function into a container image, and Artifact Registry as the container repository to store and deploy each image.
Before you begin
- 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. 
- 
          If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. 
- 
        To initialize the gcloud CLI, run the following command: 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. 
- 
          If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. 
- 
        To initialize the gcloud CLI, run the following command: gcloud init
- Ensure that your Google Cloud project has access to a container image repository.
  To configure access to a Docker repository in Artifact Registry: - Create a new Docker repository in the same location of your Google Cloud project.
gcloud artifacts repositories create REPO_NAME \ --repository-format=docker \ --location=REGION --description="DESCRIPTION" - REPO_NAMEwith the name that you choose for your Docker repository.
- REGIONwith the location in or nearest to the location of your Google Cloud project.
- DESCRIPTIONwith a description of your choice.
 For example, to create a dockerrepository inus-west2with the description "Docker repository", you run:gcloud artifacts repositories create buildpacks-docker-repo --repository-format=docker \ --location=us-west2 --description="Docker repository" 
- Verify that your repository was created:
gcloud artifacts repositories list You should see name that you choose for your Docker repository in the list. 
 
- Create a new Docker repository in the same location of your Google Cloud project.
Build a function remotely
You use the gcloud builds submit
command to build and upload your container image to your repository.
You can choose to specify your container image in the command itself or use a configuration file.
Build with command
To build without a configuration file, specify the image flag:
gcloud builds submit --pack image=LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/IMAGE_NAME
Replace:
- LOCATIONwith the region name of your container repository, for example,- us-west2
- PROJECT_IDwith the ID of your Google Cloud project.
- REPO_NAMEwith the name of your Docker repository.
- IMAGE_NAMEwith the name of your container image.
Example:
gcloud builds submit --pack image=us-west2-docker.pkg.dev/my-project-id/my-buildpacks-docker-repo
Build with configuration files
You can use a
configuration file
to define your image repository configuration
details to simply the build command. The configuration file uses the YAML file
format and must include a build step that uses the pack CLI.
- Create a YAML file name cloudbuild.yamlthat includes the URI of your container image repository.
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
Replace:
- LOCATIONwith the region name of your container repository, for example,- us-west2.
- PROJECT_IDwith the ID of your Google Cloud project.
- REPO_NAMEwith the name of your Docker repository.
- IMAGE_NAMEwith the name of your container image.
- Build the application. - If you named your configuration file - cloudbuild.yaml, you can run the following command:- gcloud builds submit .
Example: Build a sample function remotely
The following examples demonstrate how to build a sample remotely, and verify that the container image was pushed to your repository in Artifact Registry.
- Clone the sample repository to your local machine:
    git clone https://github.com/GoogleCloudPlatform/buildpack-samples.git 
- Change to the directory that contains the application sample code:
    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 
- Use gcloudto submit the application source code to 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 Replace: - LOCATIONwith the region name of your container repository. Example:- us-west2-docker.pkg.dev
- PROJECT_IDwith the ID of your Google Cloud project.
- REPO_NAMEwith the name of your Docker repository.
 
- 
    Verify that the sample function was successfully published into
    REPO_NAME:gcloud artifacts docker images list LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME Replace: - LOCATIONwith the region name of your container repository, for example,- us-west2.
- PROJECT_IDwith the ID of your Google Cloud project.
- REPO_NAMEwith the name of your Docker repository.
 
Building a function for automatic base image updates
Function containers can also be built on scratch, allowing them to be used in
combination with Cloud Run automatic security updates.
Dockerfile
You can use your existing build toolchain to create a function container image that is compatible with automatic base image updates. See instructions on how to build a container on scratch.
pack CLI
pack build IMAGE_NAME \
  --builder LOCATION-docker.pkg.dev/serverless-runtimes/google-22-full/builder/LANGUAGE:latest
  --run-image LOCATION-docker.pkg.dev/serverless-runtimes/google-22/scratch/RUNTIME_ID:latest
Replace:
- LOCATIONwith the region name of your container repository, for example,- us-west2.
- IMAGE_NAMEwith the name of your container image.
- LANGUAGEwith the language of your function, for example- nodejs.
- RUNTIME_IDwith the runtime ID, for example- nodejs22.
Cloud Build
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
  - LOCATION-docker.pkg.dev/serverless-runtimes/google-22-full/builder/LANGUAGE:latest
  - --run-image
  - LOCATION-docker.pkg.dev/serverless-runtimes/google-22/scratch/RUNTIME_ID:latest
  - --network
  - cloudbuild
images:
- LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/IMAGE_NAME
Replace:
- LOCATIONwith the region name of your container repository, for example,- us-west2.
- PROJECT_IDwith the ID of your Google Cloud project.
- REPO_NAMEwith the name of your Docker repository.
- IMAGE_NAMEwith the name of your container image.
- LANGUAGEwith the language of your function, for example- nodejs.
- RUNTIME_IDwith the runtime ID, for example- nodejs22.
What's next?
- After you build your function into a container, test it locally before deploying to Cloud Run. See Testing a Cloud Run service locally to learn more.
- To deploy your built containers to Cloud Run, follow Deploying services.
- To automate the builds and deployments of your Cloud Run services using Cloud Build triggers, see set up continuous deployment.