Riker

Build Status Gitter MIT licensed crates.io Released API docs code style: prettier pre-commit

Attention

This fork is WIP at this moment. Some changes may already be out of sync with documentation. Hopefully I will stabilize API during several weeks

Overview

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:

Website | API Docs

Example

Cargo.toml:

toml [dependencies] actors-rs = "0.1"

main.rs:

```rust use std::time::Duration; use actors_rs::*;

[derive(Default)]

struct MyActor;

// implement the Actor trait impl Actor for MyActor { type Msg = String;

fn recv(&mut self,
            _ctx: &Context<String>,
            msg: String,
            _sender: Sender) {

    println!("Received: {}", msg);
}

}

// start the system and create an actor fn main() { let sys = ActorSystem::new().unwrap();

let my_actor = sys.actor_of::<MyActor>("my-actor").unwrap();

my_actor.tell("Hello my actor!".to_string(), None);

std::thread::sleep(Duration::from_millis(500));

} ```

Associated Projects

Official crates that provide additional functionality:

Roadmap & Currently in Development

The next major theme on the project roadmap is clustering and location transparency:

Why Riker

Riker is 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 familiar actor model API which in turn makes concurrent, resilient systems programming easy.

Rust Version

Riker is currently built using the stable release.

Contributing

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:

pre-commit

The project is using pre-commit git hooks to verify committed code Make sure you install pre-commit

Documentation

actors-rs consists of 2 parts

In order to test both parts you need first run yarn to install required packages and

bash $ yarn start yarn run v1.19.0 $ lerna run --parallel start --stream lerna notice cli v3.20.2 lerna info versioning independent lerna info Executing command in 2 packages: "yarn run start" actors-rs-mkdocs: $ nopenv mkdocs serve -a localhost:8001 actors-rs-frontpage: $ echo 'visit http://localhost:8000/ to test frontpage' && gatsby develop --no-color actors-rs-frontpage: visit http://localhost:8000/ to test frontpage actors-rs-mkdocs: INFO - Building documentation... actors-rs-mkdocs: WARNING - Config value: 'pages'. Warning: The 'pages' configuration option has been deprecated and will be removed in a future release of MkDocs. Use 'nav' instead. actors-rs-mkdocs: INFO - Cleaning site directory actors-rs-mkdocs: INFO - The following pages exist in the docs directory, but are not included in the "nav" configuration: actors-rs-mkdocs: - cluster.md actors-rs-mkdocs: - io.md actors-rs-mkdocs: - persistence.md actors-rs-mkdocs: WARNING - A relative path to '../' is included in the 'nav' configuration, which is not found in the documentation files actors-rs-mkdocs: INFO - Documentation built in 0.44 seconds actors-rs-mkdocs: [I 200413 10:38:05 server:283] Serving on http://localhost:8001 ... a