zmq.rs - A native Rust implementation of ZeroMQ
DISCLAIMER: The codebase is very much a work in progress and feature incomplete. DO NOT USE IN PRODUCTION
ZeroMQ is a high-performance asynchronous messaging library that provides many popular messaging patterns for many transport types. They look and feel like Berkeley style sockets, but are fault tolerant and easier to use. This project aims to provide a native rust alternative to the reference implementation, and leverage Rust's async ecosystem.
A basic ZMTP implementation is working, but is not yet fully compliant to the spec. Integration tests against the reference implementation are also missing. External APIs are still subject to change - there are no semver or stability guarantees at the moment.
Supported transport types:
We plan to support most of the basic ZMQ sockets. The current list is as follows:
- IPC (unix only)
Supported socket patterns:
We plan to support most of the basic ZMQ messaging patterns. The current list is as follows:
- Request/Response (REQ, REP, DEALER, ROUTER)
- Publish/Subscribe (PUB, SUB)
- Pipeline (PUSH, PULL)
Contributions are welcome! See our issue tracker for a list of the things we need help with.