Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/riot-ml/riot
An actor-model multi-core scheduler for OCaml 5 🐫
https://github.com/riot-ml/riot
actor-model elixir erlang fault-tolerance multicore multicore-ocaml ocaml otp
Last synced: about 3 hours ago
JSON representation
An actor-model multi-core scheduler for OCaml 5 🐫
- Host: GitHub
- URL: https://github.com/riot-ml/riot
- Owner: riot-ml
- License: other
- Created: 2023-09-29T13:57:12.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-11-13T01:49:55.000Z (about 2 months ago)
- Last Synced: 2025-01-04T15:06:45.363Z (7 days ago)
- Topics: actor-model, elixir, erlang, fault-tolerance, multicore, multicore-ocaml, ocaml, otp
- Language: OCaml
- Homepage: https://riot.ml
- Size: 591 KB
- Stars: 592
- Watchers: 12
- Forks: 37
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGES.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-ccamel - riot-ml/riot - An actor-model multi-core scheduler for OCaml 5 🐫 (OCaml)
README
An actor-model multi-core scheduler for OCaml 5.
Quick Start |
Tutorial |
Reference
Riot is an [actor-model][actors] multi-core scheduler for OCaml 5. It brings
[Erlang][erlang]-style concurrency to the language, where lightweight processes communicate via message-passing.```ocaml
open Riottype Message.t += Hello_world
let () =
Riot.run @@ fun () ->
let pid =
spawn (fun () ->
match receive () with
| Hello_world ->
Logger.info (fun f -> f "hello world from %a!" Pid.pp (self ()));
shutdown ())
in
send pid Hello_world
```At its core Riot aims to offer:
* **Automatic multi-core scheduling** – when you spawn a new Riot process, it
will automatically get allocated on a random scheduler.* **Lightweight processes** – spawn 10 or 10,000 processes as you see fit.
* **Fast, type-safe message passing**
* **Selective receive expressions** – when receiving messages, you can skim
through a process mailbox to consume them in arbitrary order.* **Process links and monitors** to keep track of the lifecycle of processes
Riot also includes:
* **Supervisors** to build process hierarchies
* **Logging** and **Telemetry** designed to be multicore friendly
* an **Application** interface to orchestrate startup/shutdown of systems
* **Generic Servers** for designing encapsulated services like with Elixir's [GenServer][genserver]
### Non-goals
At the same time, there's a few things that Riot is not, and does not aim to be.
Primarily, Riot is not a full port of the Erlang VM and it won't support
several of its use-cases, like:
* supporting Erlang or Elixir bytecode
* hot-code reloading in live applications
* function-call level tracing in live applications
* ad-hoc distribution## Quick Start
```
opam install riot
```After that, you can use any of the [examples](./examples) as a base for your app, and run them:
```
dune exec ./my_app.exe
```## Acknowledgments
Riot is the continuation of the work I started with
[Caramel](https://github.com/leostera/caramel), an Erlang-backend for the OCaml
compiler.It was heavily inspired by [eio][eio] by the OCaml Multicore team and
[miou][miou] by [Calascibetta Romain](https://twitter.com/Dinoosaure) and the
[Robur team](https://robur.coop/), as I learned more about Algebraic Effects.
In particular the `Proc_state` is based on the `State` module in Miou.And a thousand thanks to [Calascibetta Romain](https://twitter.com/Dinoosaure)
and [Antonio Monteiro](https://twitter.com/_anmonteiro) for the discussions and
feedback.[actors]: https://en.wikipedia.org/wiki/Actor_model
[erlang]: https://erlang.org
[eio]: https://github.com/ocaml-multicore/eio
[miou]: https://github.com/robur-coop/miou
[genserver]: https://hexdocs.pm/elixir/1.12/GenServer.html