Remote caching & execution
Ordinarily, Pants executes processes locally on the system on which it is run and also caches the results of those processes locally as well. Besides this "local execution" mode of operation, Pants also supports two distributed modes of operation:
"Remote caching" where Pants store results from local process execution in a remote cache and also consumes results from that remote cache; and
"Remote execution" where Pants offloads execution of processes to a remote server (and consumes cached results from that remote server)
Pants does this by using the "Remote Execution API" to converse with the remote cache or remote execution server.
What is Remote Execution API?
Pants is compatible with remote caching and remote execution servers that comply with the Remote Execution API standard ("REAPI"). The REAPI protocol is supported by several different server and client projects including Bazel and of course Pants.
REAPI servers implement several related but distinct services: (1) a "content-addressable storage" service that stores data keyed by the hash of that data (also known as a "CAS"); (2) an "action cache service" that maps process executions to their results; and (3) an "execution service" that executes processes by using the content-addressable storage service to obtain the inputs and store the outputs from running those processes.
Remote cache servers implement the CAS and action cache services. Remote execution servers implement all three services.
Pants calls the CAS a "store server" and the execution service an "execution server." These are logically distinct in the REAPI, but in fact may be exposed to clients on the same network endpoint.
The REAPI model contains the notion of an "instance." An "instance" is a distinct deployment of a CAS and/or execution service that is given a specific name. All REAPI operations send an instance name to the server, thus a single network endpoint can conceivably support multiple REAPI deployments.
In order to use remote caching or remote execution, Pants will need access to a server that complies with REAPI. Pants is known to work with:
- Toolchain, a remote caching service designed by several of the lead maintainers of Pants specifically to work seamlessly with it.
Note: Setup of a self-hosted REAPI server is beyond the scope of this documentation. All these server projects have support channels on the BuildTeamWorld Slack. Go here to obtain an invite to that Slack.
There are a few other systems and services in this space, but
they have not, to our knowledge, been tested with Pants. Let us know if you have any experience with them!
- The remote-apis-testing project maintains a compatibility test suite of the various server and client implementations of REAPI.
Updated 9 months ago