This Gradle plugin provides a build cache implementation that uses Google Cloud Storage to store build artifacts.
The build cache takes the following options:
Option | Description |
---|---|
credentials |
JSON key file of the service account to use, otherwise GCP Application Default Credentials are used. (optional) |
bucket |
Name of the Google Cloud Storage bucket (required) |
prefix |
Path prefix for objects written to Google Cloud Storage (optional) |
refreshAfterSeconds |
Amount of time to wait before the timestamp of a cached artifact that is still in use will be renewed (optional) |
writeThreshold |
Number of bytes at which the plugin starts using a file as a buffer for writing cache entries - default 8 MiB (optional) |
There are multiple ways to use the Google Cloud Storage based build cache inside your projects.
settings.gradle
buildscript {
repositories {
maven {
url 'https://plugins.gradle.org/m2/'
}
}
dependencies {
classpath 'net.idlestate:gradle-gcs-build-cache:1.3.0'
}
}
apply plugin: 'net.idlestate.gradle-gcs-build-cache'
buildCache {
local {
enabled = false
}
remote( GCSBuildCache.class ) {
credentials = 'my-key.json' // (optional)
bucket = 'my-bucket'
prefix = 'app-cache' // (optional)
refreshAfterSeconds = 86400 // 24h (optional)
writeThreshold = 8 * 1024 * 1024 // 8 MiB
enabled = true
push = true
}
}
settings.gradle
buildscript {
repositories {
maven {
url 'https://plugins.gradle.org/m2/'
}
}
dependencies {
classpath 'net.idlestate:gradle-gcs-build-cache:1.3.0'
}
}
import net.idlestate.gradle.caching.GCSBuildCache
import net.idlestate.gradle.caching.GCSBuildCacheServiceFactory
buildCache {
local {
enabled = false
}
registerBuildCacheService( GCSBuildCache.class, GCSBuildCacheServiceFactory.class )
remote( GCSBuildCache.class ) {
credentials = 'my-key.json' // (optional)
bucket = 'my-bucket'
prefix = 'app-cache' // (optional)
refreshAfterSeconds = 86400 // 24h (optional)
writeThreshold = 8 * 1024 * 1024 // 8 MiB
enabled = true
push = true
}
}
initscript {
repositories {
maven {
url 'https://plugins.gradle.org/m2/'
}
}
dependencies {
classpath 'net.idlestate:gradle-gcs-build-cache:1.3.0'
}
}
import net.idlestate.gradle.caching.GCSBuildCache
import net.idlestate.gradle.caching.GCSBuildCacheServiceFactory
gradle.settingsEvaluated { settings ->
settings.buildCache {
local {
enabled = false
}
registerBuildCacheService( GCSBuildCache.class, GCSBuildCacheServiceFactory.class )
remote( GCSBuildCache.class ) {
credentials = 'my-key.json' // (optional)
bucket = 'my-bucket'
prefix = 'app-cache' // (optional)
refreshAfterSeconds = 86400 // 24h (optional)
writeThreshold = 8 * 1024 * 1024 // 8 MiB
enabled = true
push = true
}
}
}
% ./gradlew --build-cache --init-script init-build-cache.gradle <task>
The following steps will create a Google Cloud Storage bucket named $BUCKET
as part of the GCP project $PROJECT
in your $REGION
with private access. gsutil
is available as part of the Google Cloud SDK.
% gsutil mb -p $PROJECT -c regional -l $REGION gs://$BUCKET [...] % gsutil acl set private gs://$BUCKET [...]
To create a service account $ACCOUNT
with access to the bucket the following commands have to be executed.
% gcloud iam service-accounts create $ACCOUNT --display-name "Service account to access the Gradle build cache in Google Cloud Storage" [...] % gsutil acl ch -u $ACCOUNT@$PROJECT.iam.gserviceaccount.com:WRITE gs://$BUCKET [...]
A JSON key file $KEY_FILE
that could be used by the Gradle plugin to access the bucket is created with the following statement.
% gcloud iam service-accounts keys create $KEY_FILE --iam-account $ACCOUNT@$PROJECT.iam.gserviceaccount.com [...]
If cached artifacts should be deleted after two weeks lifecycle rules like the following should be applied to the bucket.
{
"rule":
[
{
"action": {"type": "Delete"},
"condition": {"age": 14}
}
]
}
% gsutil lifecycle set rules.json gs://$BUCKET [...]
LICENSE