Skip to main content

Configuring Dispatching

If you are deploying SpiceDB under Kubernetes, it is recommended to use the SpiceDB Operator, which will configure dispatching automatically

What is Dispatching?

Dispatching is a feature of SpiceDB where requests to SpiceDB are, in turn, forwarded onto ("dispatched") to other SpiceDB nodes within the cluster, to allow for reuse of cache.

Each SpiceDB node maintains an in-memory cache of permissions queries it has resolved in the past; when a new permissions query is encountered by one node, its answer may be present on another node, so SpiceDB will forward the request onward to the other node to check the shared cache.

For more details on how dispatching works, see the Consistent Hash Load Balancing for gRPC article.

Configuring Dispatch in Kubernetes

If not using the SpiceDB Operator, the dispatch-upstream-addr should be of the form kubernetes:///spicedb.default:50053 where spicedb.default is the Kubernetes Service in which SpiceDB is accessible.

Configuring Dispatch in non-Kubernetes Environments

Non-Kubernetes based dispatching relies upon DNS updates, which means it can become stale if DNS is changing. This is not recommended unless DNS updates are rare.

To enable dispatch, the following flags must be specified:

spicedb serve --dispatch-cluster-enabled=true --dispatch-upstream-addr=upstream-addr ...

or via environment variables with the SPICEDB_ prefix:

SPICEDB_DISPATCH_CLUSTER_ENABLED=true SPICEDB_DISPATCH_UPSTREAM_ADDR=upstream-addr spicedb serve ...

The upstream-addr should be the DNS address of the load balancer at which all SpiceDB nodes are accessible at the default dispatch port of :50053.