- NAME
-
- gcloud builds submit - submit a build using Cloud Build
- SYNOPSIS
-
-
gcloud builds submit
[[SOURCE
]--no-source
] [--async
] [--no-cache
] [--default-buckets-behavior
=DEFAULT_BUCKETS_BEHAVIOR
] [--dir
=DIR
] [--disk-size
=DISK_SIZE
] [--gcs-log-dir
=GCS_LOG_DIR
] [--gcs-source-staging-dir
=GCS_SOURCE_STAGING_DIR
] [--git-source-dir
=GIT_SOURCE_DIR
] [--git-source-revision
=GIT_SOURCE_REVISION
] [--ignore-file
=IGNORE_FILE
] [--machine-type
=MACHINE_TYPE
] [--polling-interval
=POLLING_INTERVAL
; default=1] [--region
=REGION
] [--revision
=REVISION
] [--service-account
=SERVICE_ACCOUNT
] [--substitutions
=[KEY
=VALUE
,…]] [--suppress-logs
] [--timeout
=TIMEOUT
] [--worker-pool
=WORKER_POOL
] [--config
=CONFIG
; default="cloudbuild.yaml" |--pack
=[builder
=BUILDER
],[env
=ENV
],[image
=IMAGE
] |--tag
=TAG
,-t
TAG
] [GCLOUD_WIDE_FLAG …
]
-
- DESCRIPTION
-
Submit a build using Cloud Build.
When the
builds/use_kaniko
property isTrue
, builds submitted with--tag
will use Kaniko (https://github.com/GoogleContainerTools/kaniko) to execute builds. Kaniko executes directives in a Dockerfile, with remote layer caching for faster builds. By default, Kaniko will cache layers for 6 hours. To override this, set thebuilds/kaniko_cache_ttl
property. - EXAMPLES
-
To submit a build with source located at storage URL
gs://bucket/object.zip
:gcloud builds submit "gs://bucket/object.zip" --tag=gcr.io/my-project/image
To submit a build with source located at storage URL
gs://bucket/object.zip
using config fileconfig.yaml
:gcloud builds submit "gs://bucket/object.zip" --tag=gcr.io/my-project/image --config=config.yaml
To submit a build with local source
source.tgz
asynchronously:gcloud builds submit "source.tgz" --tag=gcr.io/my-project/image --async
To submit a build with source from a Git repository
https://github.com/owner/repo
:gcloud builds submit "https://github.com/owner/repo" --git-source-revision=main --config=config.yaml
To submit a build with source from a 2nd-gen Cloud Build repository resource
projects/my-project/locations/us-west1/connections/my-conn/repositories/my-repo
:gcloud builds submit "projects/my-project/locations/us-west1/connections/my-conn/repositories/my-repo" --revision=main
To submit a build with source from a Developer Connect GitRepositoryLink resource
projects/my-project/locations/us-west1/connections/my-conn/gitRepositoryLinks/my-repo-link
:gcloud builds submit "projects/my-project/locations/us-west1/connections/my-conn/gitRepositoryLinks/my-repo-link" --revision=main
- POSITIONAL ARGUMENTS
-
-
At most one of these can be specified:
- [
SOURCE
] -
The location of the source to build. The location can be a directory on a local
disk, a gzipped archive file (.tar.gz) in Google Cloud Storage, or a Git repo
url starting with http:// or https://. If the source is a local directory, this command
skips the files specified in the
--ignore-file
. If--ignore-file
is not specified, use.gcloudignore
file. If a.gcloudignore
file is absent and a.gitignore
file is present in the local source directory, gcloud will use a generated Git-compatible.gcloudignore
file that respects your .gitignored files. The global.gitignore
is not respected. For more information on.gcloudignore
, seegcloud topic gcloudignore
. --no-source
- Specify that no source should be uploaded with this build.
- [
-
At most one of these can be specified:
- FLAGS
-
--async
- Return immediately, without waiting for the operation in progress to complete.
--no-cache
-
If set, disable layer caching when building with Kaniko.
This has the same effect as setting the builds/kaniko_cache_ttl property to 0 for this build. This can be useful in cases where Dockerfile builds are non-deterministic and a non-deterministic result should not be cached.
--default-buckets-behavior
=DEFAULT_BUCKETS_BEHAVIOR
-
How default buckets are setup.
DEFAULT_BUCKETS_BEHAVIOR
must be one of:default-logs-bucket-behavior-unspecified
,legacy-bucket
,regional-user-owned-bucket
. --dir
=DIR
-
Directory, relative to the source root, in which to run the build. This is used
when the build source is a 2nd-gen Cloud Build repository resource, or a
Developer Connect GitRepositoryLink resource. This must be a relative path. If a
step's
dir
is specified and is an absolute path, this value is ignored for that step's execution. --disk-size
=DISK_SIZE
- Machine disk size (GB) to run the build.
--gcs-log-dir
=GCS_LOG_DIR
-
A directory in Google Cloud Storage to hold build logs. If this field is not
set,
gs://[PROJECT_NUMBER].cloudbuild-logs.googleusercontent.com/
will be created and used orgs://[PROJECT_NUMBER]-[builds/region]-cloudbuild-logs
is used when you set--default-buckets-behavior
toREGIONAL_USER_OWNED_BUCKET
. --gcs-source-staging-dir
=GCS_SOURCE_STAGING_DIR
-
A directory in Google Cloud Storage to copy the source used for staging the
build. If the specified bucket does not exist, Cloud Build will create one. If
you don't set this field,
gs://[PROJECT_ID]_cloudbuild/source
is used orgs://[PROJECT_ID]_[builds/region]_cloudbuild/source
is used when you set--default-buckets-behavior
toREGIONAL_USER_OWNED_BUCKET
andbuilds/region
is notglobal
. --git-source-dir
=GIT_SOURCE_DIR
-
Directory, relative to the source root, in which to run the build. This must be
a relative path. If a step's
dir
is specified and is an absolute path, this value is ignored for that step's execution. --git-source-revision
=GIT_SOURCE_REVISION
-
Revision to fetch from the Git repository such as a branch, a tag, a commit SHA,
or any Git ref to run the build.
Cloud Build uses
git fetch
to fetch the revision from the Git repository; therefore make sure that the string you provide forrevision
is parsable by the command. For information on string values accepted bygit fetch
, see https://git-scm.com/docs/gitrevisions#_specifying_revisions. For information ongit fetch
, see https://git-scm.com/docs/git-fetch. --ignore-file
=IGNORE_FILE
-
Override the
.gcloudignore
file and use the specified file instead. --machine-type
=MACHINE_TYPE
-
Machine type used to run the build.
MACHINE_TYPE
must be one of:e2-highcpu-32
,e2-highcpu-8
,e2-medium
,n1-highcpu-32
,n1-highcpu-8
. --polling-interval
=POLLING_INTERVAL
; default=1- Amount of time in seconds to wait between polling build status.
--region
=REGION
-
The region of the Cloud Build Service to use. Must be set to a supported region
name (e.g.
us-central1
). If unset,builds/region
, which is the default region to use when working with Cloud Build resources, is used. If builds/region is unset, region is set toglobal
. Note: Region must be specified in 2nd gen repo;global
is not supported. --revision
=REVISION
-
Revision to fetch from the Git repository such as a branch, a tag, a commit SHA,
or any Git ref to run the build. This is used when the build source is a 2nd-gen
Cloud Build repository resource, or a Developer Connect GitRepositoryLink
resource.
Cloud Build uses
git fetch
to fetch the revision from the Git repository; therefore make sure that the string you provide forrevision
is parsable by the command. For information on string values accepted bygit fetch
, see https://git-scm.com/docs/gitrevisions#_specifying_revisions. For information ongit fetch
, see https://git-scm.com/docs/git-fetch. --service-account
=SERVICE_ACCOUNT
- The service account to use with this build. If unset, the default service account will be used.
--substitutions
=[KEY
=VALUE
,…]-
Parameters to be substituted in the build specification.
For example (using some nonsensical substitution keys; all keys must begin with an underscore):
gcloud builds submit . --config config.yaml --substitutions _FAVORITE_COLOR=blue,_NUM_CANDIES=10
This will result in a build where every occurrence of
${_FAVORITE_COLOR}
in certain fields is replaced by "blue", and similarly for${_NUM_CANDIES}
and "10".Only the following built-in variables can be specified with the
--substitutions
flag: REPO_NAME, BRANCH_NAME, TAG_NAME, REVISION_ID, COMMIT_SHA, SHORT_SHA.For more details, see: https://cloud.google.com/cloud-build/docs/api/build-requests#substitutions
--suppress-logs
- If set, build logs not streamed to stdout.
--timeout
=TIMEOUT
-
Maximum time a build is run before it is failed as
TIMEOUT
. It is specified as a duration; for example, "2h15m5s" is two hours, fifteen minutes, and five seconds. If you don't specify a unit, seconds is assumed. For example, "10" is 10 seconds. Overrides the defaultbuilds/timeout
property value for this command invocation. -
Worker pool only flags.
--worker-pool
=WORKER_POOL
- Specify a worker pool for the build to run in. Format: projects/{project}/locations/{region}/workerPools/{workerPool}.
-
At most one of these can be specified:
--config
=CONFIG
; default="cloudbuild.yaml"- The YAML or JSON file to use as the build configuration file.
--pack
=[builder
=BUILDER
],[env
=ENV
],[image
=IMAGE
]-
Uses CNCF buildpack to create the app
image. The app "image" key/value must be provided. The app image name must be in
the
gcr.io
orpkg.dev
namespace. To specify your own builder image use the optional "builder" key/value argument. By defaultgcr.io/buildpacks/builder
is used. To pass environment variables to the builder use the optional "env" key/value argument where value is a list of key values using escaping if necessary. --tag
=TAG
,-t
TAG
-
The tag to use with a "docker build" image creation. Cloud Build will run a
remote "docker build -t $TAG .", where $TAG is the tag provided by this flag.
The tag must be in the
gcr.io
orpkg.dev
namespace. Specify a tag if you want Cloud Build to build using a Dockerfile instead of a build config file. If you specify a tag in this command, your source must include a Dockerfile. For instructions on building using a Dockerfile see https://cloud.google.com/cloud-build/docs/quickstart-build.
- GCLOUD WIDE FLAGS
-
These flags are available to all commands:
--access-token-file
,--account
,--billing-project
,--configuration
,--flags-file
,--flatten
,--format
,--help
,--impersonate-service-account
,--log-http
,--project
,--quiet
,--trace-token
,--user-output-enabled
,--verbosity
.Run
$ gcloud help
for details. - NOTES
-
These variants are also available:
gcloud alpha builds submit
gcloud beta builds submit
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-01-14 UTC.