Riker is a framework for building modern, concurrent and resilient systems using the Rust language. Riker aims to make working with state and behavior in concurrent systems as easy and scalable as possible. The Actor Model has been chosen to realize this because of the familiar and inherent simplicity it provides while also providing strong guarantees that are easy to reason about. The Actor Model also provides a firm foundation for resilient systems through the use of the actor hierarchy and actor supervision.
Riker provides:
futures::execution::ThreadPool
by defaultCargo.toml
:
toml
[dependencies]
riker = "0.1.8"
riker-default = "0.1.8"
main.rs
:
```rust
extern crate riker;
extern crate riker_default;
extern crate log;
use std::time::Duration; use riker::actors::*; use riker_default::DefaultModel;
struct MyActor;
// implement the Actor trait impl Actor for MyActor { type Msg = String;
fn receive(&mut self,
_ctx: &Context<Self::Msg>,
msg: Self::Msg,
_sender: Option<ActorRef<Self::Msg>>) {
debug!("Received: {}", msg);
}
}
// provide factory and props methods
impl MyActor {
fn actor() -> BoxActor
fn props() -> BoxActorProd<String> {
Props::new(Box::new(MyActor::actor))
}
}
// start the system and create an actor
fn main() {
let model: DefaultModel
let props = MyActor::props();
let my_actor = sys.actor_of(props, "my-actor").unwrap();
my_actor.tell("Hello my actor!".to_string(), None);
std::thread::sleep(Duration::from_millis(500));
} ```
Riker's core functionality is provided by modules defined as part of a 'model'. Every application defines a Model
to describe the modules to be used. Everything from database storage, to logging, to the underlying dispatcher that executes actors is a module.
A default Model
riker-default makes it easy to get started. You can also use this default model as part of a custom model.
Official crates that provide additional functionality:
transform!
and 'ask'The next major theme on the project roadmap is clustering and location transparency:
We believe there is no greater need than now for a full-featured actor model implementation that scales to hundreds or thousands of microservices and that equally can run exceptionally well on resource limited hardware to drive drones, IoT and robotics. The Rust language makes this possible.
Rust empowers developers with control over memory management, requiring no garbage collection and runtime overhead, while also providing modern semantics and expressive syntax such as the trait system. The result is a language that can solve problems equally for Web and IoT.
Riker adds to this by providing a famililar actor model API which in turn makes concurrent, resilent systems programming easy.
Riker is currently built using the latest Rust Nightly. Starting from between Riker 0.2
and 0.3
we expect to build against Rust Stable with support for specific minimum versions.
Riker is looking for contributors - join the project! You don't need to be an expert in actors, concurrent systems, or even Rust. Great ideas come from everyone.
There are multiple ways to contribute: