Bazel can be configured to use a remote cache and to execute build and test actions remotely.
A Bazel build consists of many actions. Each action is defined by the command line, the environment variables, the list of input files and hashes of their contents, and the list of output files or output directories. The result of an action is a complete list of output files and hashes of their contents. Bazel can use a remote cache to store and lookup action results. Conceptually, the remote cache consists of two parts: (1) a map of action hashes to action results, and (2) a content-addressable store (CAS) of output files.
When it's configured to use a remote cache, Bazel computes a hash for each action, and then looks up the hash in the cache. If the cache already contains a result for that action, then Bazel downloads the output files from the CAS. Otherwise it executes the action locally, uploads the files to the CAS, and then adds the action result to the cache.
Starting at version 0.5.0, Bazel supports two caching protocols:
If all you need is just distributed caching this is probably the most reliable path as the REST APIs are simple and will remain stable.
For a quick setup, you can use Hazelcast's REST interface. Alternatively you can use the NGINX server with WebDAV, or the Apache HTTP Server with WebDAV.
We recommend editing your ~/.bazelrc to enable remote caching using the HTTP REST protocol. You will need to replace http://server-address:port/cache with the correct address for your HTTP REST server:
build --spawn_strategy=remote build --remote_rest_cache=REPLACE_THIS:http://server-address:port/cache # Bazel currently doesn't support remote caching in combination with workers. # These two lines override the default strategy for Javac and Closure # actions, so that they are also remotely cached. # Follow https://github.com/bazelbuild/bazel/issues/3027 for more details: build --strategy=Javac=remote build --strategy=Closure=remote
Bazel currently supports the following digest functions with the remote worker: SHA1, SHA256, and MD5. It defaults to SHA256. The digest function is passed via the --host_jvm_args=-Dbazel.DigestFunction=### startup option.
Hazelcast is a distributed in-memory cache which can be used by Bazel as a remote cache. You can download the standalone Hazelcast server here.
A simple single-machine setup is to run a single Hazelcast server with REST enabled. The REST endpoint will be http://localhost:5701/hazelcast/rest/maps/. Run the Hazelcast server with REST using this command:
java -cp hazelcast-all-3.8.5.jar -Dhazelcast.rest.enabled=true com.hazelcast.core.server.StartServer
You can also use Bazel with a Hazelcast cluster - as long as REST is enabled -, and also customize the configuration. Please see the Hazelcast documentation for more details.
First you need to set up NGINX with WebDAV support. On Debian or Ubuntu Linux, you can install the nginx-extras package. On OSX you can install the nginx-full package from homebrew with brew install nginx-full --with-webdav.
Once installed, edit nginx.conf with a section for uploading and serving cache objects.
location /cache/ {
    root /some/document/root;
    dav_methods PUT;
    autoindex on;
    allow all;
    client_max_body_size 256M;
}
You will need to change /some/document/root to a valid directory where NGINX can write to and read from. You may need to change client_max_body_size option to a larger value in case the cache object is too large.
Assuming Apache HTTP Server is installed with DAV modules installed. You need to edit httpd.conf to enable the following modules:
LoadModule dav_module libexec/apache2/mod_dav.so LoadModule dav_fs_module libexec/apache2/mod_dav_fs.so
Edit httpd.conf to use a directory for uploading and serving cache objects. You may want to edit this directory to include security control.
<Directory "/some/directory/for/cache">
    AllowOverride None
    Require all granted
    Options +Indexes
    Dav on
    <Limit HEAD OPTIONS GET POST PUT DELETE>
        Order Allow,Deny
        Allow from all
    </Limit>
    <LimitExcept HEAD OPTIONS GET POST PUT DELETE>
        Order Deny,Allow
        Deny from all
    </LimitExcept>
</Directory>
We're working on a gRPC protocol that supports both remote caching and remote execution. As of this writing, there is only a single server-side implementation, which is not intended for production use.
We recommend editing your ~/.bazelrc to enable remote caching using the gRPC protocol. Use the following build options to use the gRPC CAS endpoint for sharing build artifacts. Change REPLACE_THIS:address:8080 to the correct server address and port number.
build --spawn_strategy=remote build --remote_cache=REPLACE_THIS:address:8080 # Bazel currently doesn't support remote caching in combination with workers. # These two lines override the default strategy for Javac and Closure # actions, so that they are also remotely cached. # Follow https://github.com/bazelbuild/bazel/issues/3027 for more details: build --strategy=Javac=remote build --strategy=Closure=remote
Bazel currently provides a sample gRPC CAS implementation with a SimpleBlobStore as caching backend. To use it you need to clone from Bazel and then build it with:
bazel build //src/tools/remote:worker
The following command will then start the cache server listening on port 8080 using a local in-memory cache:
bazel-bin/src/tools/remote/worker --listen_port=8080