Parts of Busan that need some focused development efforts to get somewhere to something usable.
- Actor Supervision
- Lifecycle Management (pre-condition to supervision)
- shutdown trees
- death-watch / poison-pill
- ACK messages (pre-condition to various forms of message routing)
- Message routing
- Dead letter queue
- Routers/Load Balancers/Proxies/etc.
- Stats & Observability
- Behavior system
- Message matching ergonomics
- Document send methods in
actor.rs
- Is the resolution step persisted on addresses on copy/move?
- Block on child spawn - the actor should be allocated... I think
- Do not allow for "dangling" actors created after shutdown has been started
- crossbeam channel
send
macro that asserts sending, something like:macro_rules! debug_assert_send { let result = channel.send(...) debug_assert!(result.is_ok(), "Failed to send along channel..."); match result { Ok(_) => (), Err(e) => error!("Failed to send along chanel... {}", e); } }
- Refactor the shutdown logic into a separate shutdown manager
cargo doc --open
to view the rustdocs for all dependencies (all)rustup doc
to view the rustdocs for the standard library and other useful tools like 'Rust by Example'- crates with special docs
- ratatui - see
README.md
for npm instructions to launch the site (git lfs already installed) - tokio - see
README.md
for instruction to build / run the docs
- ratatui - see
- little book of macros
mdbook serve --port 1234 --open