6 releases

0.3.2 Dec 5, 2024
0.3.1 Dec 5, 2024
0.3.0 Sep 10, 2024
0.2.1 Aug 22, 2024
0.1.0-alpha.0 Jul 16, 2024

#320 in Asynchronous

Download history 13/week @ 2024-09-26 12/week @ 2024-10-03 8/week @ 2024-10-10 45/week @ 2024-10-17 50/week @ 2024-10-24 45/week @ 2024-10-31 69/week @ 2024-11-07 132/week @ 2024-11-14 78/week @ 2024-11-21 155/week @ 2024-11-28 293/week @ 2024-12-05 100/week @ 2024-12-12 51/week @ 2024-12-19 1/week @ 2024-12-26 35/week @ 2025-01-02 101/week @ 2025-01-09

198 downloads per month

MIT license

155KB
2.5K SLoC

Documentation crates.io Examples Discord Twitter

Restate Rust SDK

Restate is a system for easily building resilient applications using distributed durable async/await. This repository contains the Restate SDK for writing services using Rust.

Community

Using the SDK

Add Restate and Tokio as dependencies:

[dependencies]
restate-sdk = "0.1"
tokio = { version = "1", features = ["full"] }

Then you're ready to develop your Restate service using Rust:

use restate_sdk::prelude::*;

#[restate_sdk::service]
trait Greeter {
    async fn greet(name: String) -> HandlerResult<String>;
}

struct GreeterImpl;

impl Greeter for GreeterImpl {
    async fn greet(&self, _: Context<'_>, name: String) -> HandlerResult<String> {
        Ok(format!("Greetings {name}"))
    }
}

#[tokio::main]
async fn main() {
    // To enable logging/tracing
    // tracing_subscriber::fmt::init();
    HttpServer::new(
        Endpoint::builder()
            .with_service(GreeterImpl.serve())
            .build(),
    )
    .listen_and_serve("0.0.0.0:9080".parse().unwrap())
    .await;
}

Logging

The SDK uses tokio's tracing crate to generate logs. Just configure it as usual through tracing_subscriber to get your logs.

Versions

The Rust SDK is currently in active development, and might break across releases.

The compatibility with Restate is described in the following table:

Restate Server\sdk-rust 0.0/0.1/0.2 0.3
1.0 βœ… ❌
1.1 βœ… βœ…

Contributing

We’re excited if you join the Restate community and start contributing! Whether it is feature requests, bug reports, ideas & feedback or PRs, we appreciate any and all contributions. We know that your time is precious and, therefore, deeply value any effort to contribute!

Building the SDK locally

Prerequisites:

To build and test the SDK:

just verify

Releasing

You need the Rust toolchain. To verify:

just verify

To release we use cargo-release:

cargo release <VERSION> --exclude test-services --workspace

Dependencies

~13–25MB
~461K SLoC