Rust implementation of Dataspaces, Syndicate, and a high-speed networked dataspace broker.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Go to file
Tony Garnock-Jones a340b127d7
Release independent packages
1 month ago
dev-scripts More updates to gatekeeper protocol 1 month ago
docker Use busybox as base rather than a completely empty image, for convenience 10 months ago
syndicate Release independent packages 1 month ago
syndicate-macros Release independent packages 1 month ago
syndicate-server Release independent packages 1 month ago
syndicate-tools Release independent packages 1 month ago
.gitignore Update deps; in particular, get preserves 3.0, which has the fixed numerics/symbols syntax 2 months ago
Cargo.lock Release independent packages 1 month ago
Cargo.toml syndicate-macaroon 5 months ago
Cross.toml Makefile & Cross.toml hack to work around an aarch64 cross-compilation issue ( 1 year ago
Makefile Allow override of PROTOCOLS_BRANCH 1 month ago Update README 2 years ago 1 year ago
rust-toolchain Split out syndicate-server crate 2 years ago
syndicate-rs-server.png 2 years ago


A Rust implementation of:

  • the Syndicated Actor model, including assertion-based communication, failure-handling, capability-style security, dataspace entities, and facets as a structuring principle;

  • the Syndicate network protocol, including

    • a high-speed Dataspace indexing structure (; see also from syndicate-rkt) and

    • a standalone Syndicate protocol "broker" service (roughly comparable in scope and intent to D-Bus); and

  • a handful of example programs.

The Syndicate/rs server running.
The Syndicate/rs server running.


git clone
cd syndicate-rs
cargo build --release
./target/release/syndicate-server -p 8001

Running the examples

In one window, start the server:

./target/release/syndicate-server -p 8001

Then, choose one of the examples below.

Producer/Consumer (sending messages)

In a second window, run a "consumer" process:


Finally, in a third window, run a "producer" process:


State producer/consumer (state replication)

Replace producer with state-producer and consumer with state-consumer, respectively, in the instructions of the previous subsection to demonstrate Syndicate state replication.

Pingpong example (latency)

In a second window, run

./target/release/examples/pingpong pong

and in a third window, run

./target/release/examples/pingpong ping

The order is important - the difference between ping and pong is about who kicks off the pingpong session.

Performance note

You may find better performance by restricting the server to fewer cores than you have available. For example, for me, running

taskset -c 0,1 ./target/release/syndicate-server -p 8001

roughly quadruples throughput for a single producer/consumer pair, on my 48-core AMD CPU.