#actor-framework #low-latency #long-running #telemetry #actor-model #state #supervisor

steady_state

Framework for building long running low latency actor based services on Linux. Provides visual telemetry to watch data flows between actors. Uses Erlang style supervisors to defend against panics and uses non blocking async ringbuffers for inter actor communication.

5 releases

0.1.0 Dec 2, 2024
0.0.31 Nov 29, 2024
0.0.19 Jul 19, 2024
0.0.11 Mar 26, 2024

#89 in Concurrency

Download history 185/week @ 2024-09-11 352/week @ 2024-09-18 212/week @ 2024-09-25 253/week @ 2024-10-02 84/week @ 2024-10-09 359/week @ 2024-10-16 141/week @ 2024-10-23 19/week @ 2024-10-30 93/week @ 2024-11-06 31/week @ 2024-11-13 166/week @ 2024-11-20 396/week @ 2024-11-27 444/week @ 2024-12-04 262/week @ 2024-12-11 40/week @ 2024-12-18 2/week @ 2024-12-25

806 downloads per month

MIT license

740KB
13K SLoC

Steady State: The Foundation of Resilient Rust Services

Welcome to the Steady State Core, the backbone of the Steady State framework designed to empower developers to build resilient, high-performance services with ease.

Overview

The Steady State Core focuses on delivering essential features that ensure safety, reliability, and performance:

  • Safety and Concurrency: Leverage Rust's memory safety guarantees with actor-based supervised threading for secure and manageable concurrency.

  • High Throughput: Handle high message volumes efficiently with support for batch processing in actors.

  • Rapid Prototyping: Use Graphviz DOT files to model your actor graph, then generate Rust code to focus on your business logic.

  • Visibility and Observability: Built-in telemetry provides real-time insights, enabling you to identify and resolve bottlenecks swiftly.

    Telemetry Visualization Example An animated GIF demonstrating real-time telemetry visualization in action.

    Complex Graph Snapshot A snapshot of a more complex example.

Key Features

Built-in Prometheus Integration

  • Metrics Collection: Automatically gather performance metrics without additional setup.
  • Customizable Metrics: Extend and customize metrics to suit your application's needs.

Comprehensive Testing Framework

  • Actor Unit Testing: Write tests for individual actors to ensure they function correctly in isolation.
  • Graph Testing: Validate the behavior of the entire actor graph under various conditions.
  • Mocking Support: Use mock actors to simulate components and external systems for thorough testing.

Flexible Actor Management

  • Async Made Easy: Simplify asynchronous operations with built-in support.
  • Thread Configuration: Assign actors to single threads or have actors share threads for greater scale.

Clean Shutdown Logic

  • Signal Handling: Respond to system signals to initiate a clean shutdown sequence.
  • Ordered Teardown: Ensure actors shut down in a controlled manner to maintain system integrity.

Getting Started

1. Define Your Actor Graph

  • Write a Graphviz DOT file with annotations to model your actor system.
  • Use clear labels to specify actor properties and relationships.

2. Generate Your Project

  • Utilize the cargo-steady-state tool to generate your Rust service project from the DOT file.
  • Focus on implementing your business logic rather than boilerplate code.

3. Implement and Test

  • Implement your actors' behavior within the generated framework.
  • Write unit tests for actors and integration tests for the actor graph.
  • Leverage the built-in testing framework for robust validation.

Roadmap

  • Enhanced Test Coverage: Increase code coverage to ensure robustness.
  • Video Tutorials: Produce educational content to help developers adopt Steady State easily.
  • Distributed Actor Support: Enable actors to communicate across network boundaries.
  • Performance Optimizations: Continuously improve processing efficiency.
  • Expanded Actor Library: Provide more pre-built actors for common patterns.

Contributing

We welcome contributions from the community. Whether it's bug reports, feature requests, or pull requests, your input is invaluable.

License

Steady State Core is open-source under the MIT License. You are free to use, modify, and distribute it under the terms of the license.

Sponsor Steady State on GitHub Today


By sponsoring Steady State, you're not just supporting a project—you're investing in the future of resilient, high-performance service development in Rust. Together, we can build solutions that keep businesses moving forward.


Feel free to reach out if you have any questions or need further assistance. Thank you for considering supporting Steady State!

Dependencies

~11–24MB
~367K SLoC