Quickstart: Deploy to Cloud Run from a Git repository
This page shows you how to continuously deploy from a Git repository to Cloud Run.
To follow step-by-step guidance for this task directly in the Google Cloud console, click Guide me:
Full instructions for this process can be found at Continuous deployment from Git using Cloud Build.
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 role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
If you're using an existing project for this guide, verify that you have the permissions required to complete this guide. If you created a new project, then you already have the required permissions.
-
Verify that billing is enabled for your Google Cloud project.
-
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 role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
If you're using an existing project for this guide, verify that you have the permissions required to complete this guide. If you created a new project, then you already have the required permissions.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Cloud Build API.
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. If you are under a domain restriction organization policy restricting unauthenticated invocations for your project, you will need to access your deployed service as described under Testing private services.
- Review Cloud Run pricing or estimate costs with the pricing calculator.
Required roles
To get the permissions that you need to complete this quickstart, ask your administrator to grant you the following IAM roles:
-
Cloud Run Source Developer (
roles/run.sourceDeveloper) on the service -
Cloud Run Admin (
roles/run.admin) on the project -
Service Account User (
roles/iam.serviceAccountUser) on the service identity -
Logs Viewer (
roles/logging.viewer) on the project
For more information about granting roles, see Manage access to projects, folders, and organizations.
You might also be able to get the required permissions through custom roles or other predefined roles.
Create a repository from template
To create a repository:
Go to the template repository:
Node.js
Go to github.com/GoogleCloudPlatform/cloud-run-microservice-template-nodejs
Python
Go to github.com/GoogleCloudPlatform/cloud-run-microservice-template-python
Go
Go to github.com/GoogleCloudPlatform/cloud-run-microservice-template-go
Java
Go to github.com/GoogleCloudPlatform/cloud-run-microservice-template-java
Click Run on Google Cloud.
Select Create a new repository.
In the form, enter a repository name.
Click Create repository from template.
Deploy from the repository
To deploy from the repository:
In the Google Cloud console, go to the Cloud Run page:
Select Services from the menu, and click Deploy container.
In the Create service, ensure the Continuously deploy from a repository option is selected.
In the form, click Set up Cloud Build.
In the right panel:
Under Repository, select the newly created repository. If you haven't already authenticated, you might be required to do so. Use the authenticate link under the Repository Provider field.
Check the confirmation agreement about GitHub and Google Cloud interactivity.
Click Next.
Under Build Type, select Google Cloud Buildpacks.
Click Save.
In the Create service form:
Confirm the name of the service. It will be automatically populated with the repository name.
In the Region pulldown menu, select the region where you want your service located.
Under Authentication, select Allow public access. If you don't have permissions (Cloud Run Admin role) to select this, the service will deploy and require authentication.
Click Create to deploy the sample repository to Cloud Run and wait for the deployment to finish.
Click the displayed URL link to run the deployed container.
Cloud Run locations
Cloud Run is regional, which means the infrastructure that
runs your Cloud Run services is located in a specific region and is
managed by Google to be redundantly available across
all the zones within that region.
Meeting your latency, availability, or durability requirements are primary
factors for selecting the region where your Cloud Run services are run.
You can generally select the region nearest to your users but you should consider
the location of the other Google Cloud
products that are used by your Cloud Run service.
Using Google Cloud products together across multiple locations can affect
your service's latency as well as cost.
Cloud Run is available in the following regions:
Subject to Tier 1 pricing
asia-east1(Taiwan)asia-northeast1(Tokyo)asia-northeast2(Osaka)asia-south1(Mumbai, India)europe-north1(Finland) leaf icon Low CO2europe-north2(Stockholm) leaf icon Low CO2europe-southwest1(Madrid) leaf icon Low CO2europe-west1(Belgium) leaf icon Low CO2europe-west4(Netherlands) leaf icon Low CO2europe-west8(Milan)europe-west9(Paris) leaf icon Low CO2me-west1(Tel Aviv)northamerica-south1(Mexico)us-central1(Iowa) leaf icon Low CO2us-east1(South Carolina)us-east4(Northern Virginia)us-east5(Columbus)us-south1(Dallas) leaf icon Low CO2us-west1(Oregon) leaf icon Low CO2
Subject to Tier 2 pricing
africa-south1(Johannesburg)asia-east2(Hong Kong)asia-northeast3(Seoul, South Korea)asia-southeast1(Singapore)asia-southeast2(Jakarta)asia-south2(Delhi, India)australia-southeast1(Sydney)australia-southeast2(Melbourne)europe-central2(Warsaw, Poland)europe-west10(Berlin)europe-west12(Turin)europe-west2(London, UK) leaf icon Low CO2europe-west3(Frankfurt, Germany)europe-west6(Zurich, Switzerland) leaf icon Low CO2me-central1(Doha)me-central2(Dammam)northamerica-northeast1(Montreal) leaf icon Low CO2northamerica-northeast2(Toronto) leaf icon Low CO2southamerica-east1(Sao Paulo, Brazil) leaf icon Low CO2southamerica-west1(Santiago, Chile) leaf icon Low CO2us-west2(Los Angeles)us-west3(Salt Lake City)us-west4(Las Vegas)
If you already created a Cloud Run service, you can view the region in the Cloud Run dashboard in the Google Cloud console.
Update the service
To make changes to the service:
Push a commit to the main branch of the repository.
Refresh the Cloud Run service to see the status of the update.
Cloud Run automatically scales your container instances based on demand, and you only pay for the CPU, memory, and networking consumed during request processing.
Clean up
To avoid additional charges to your Google Cloud account, delete all the resources you deployed with this quickstart.
Delete your repository
Cloud Run doesn't charge you when your deployed service isn't in use. However, you might still be charged for storing the container image in Artifact Registry. To delete Artifact Registry repositories, follow the steps in Delete repositories in the Artifact Registry documentation.
Delete your service
Cloud Run services don't incur costs until they receive requests. To delete your Cloud Run service, follow one of these steps:
Console
To delete a service:
In the Google Cloud console, go to the Cloud Run Services page:
Locate the service you want to delete in the services list, and click its checkbox to select it.
Click Delete. This deletes all revisions of the service.
gcloud
To delete a service, run the following command:
gcloud run services delete SERVICE --region REGION
Replace the following:
- SERVICE: name of your service.
- REGION: Google Cloud region of the service.
Delete your test project
Deleting your Google Cloud project stops billing for all resources in that project. To release all Google Cloud resources in your project, follow these steps:
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.