A rust crate to work with RPC and nonRPC calls using rabbitmq. https://crates.io/crates/bunbun-worker/
Find a file
Barna Máté ee1bb1abdf client: added timeout
- also created a new basiccalloptions that includes message versioning and such

server: now message versioning works.
2024-11-14 19:28:10 +01:00
src client: added timeout 2024-11-14 19:28:10 +01:00
.gitignore initial release 2024-10-24 20:42:40 +02:00
Cargo.lock initial release 2024-10-24 20:42:40 +02:00
Cargo.toml client: removed the bunbun part 2024-11-14 17:59:36 +01:00
deny.toml initial release 2024-10-24 20:42:40 +02:00
flake.lock initial release 2024-10-24 20:42:40 +02:00
flake.nix initial release 2024-10-24 20:42:40 +02:00
LICENSE initial release 2024-10-24 20:42:40 +02:00
README.md client: removed the bunbun part 2024-11-14 17:59:36 +01:00
taplo.toml initial release 2024-10-24 20:42:40 +02:00

BunBun-Worker

bunbun-worker is a panic-safe multithreaded job-runner server/client library for rust. It supports RPC and regular (non-rpc) calls. As of right now only rabbitmq is supported but gRPC will be added too.

Disclaimer
This crate is still under development, meaning api's may change on every commit...

Introduction

bunbun-worker was made to provide a way for microservices written in rust to communicate to each other by dispatching jobs that may return data and those who don't.

Rpc

Remote procedure call, as it's name says is a message that can be sent to a remote microservice to be processed and the result to be returned. In bunbun-worker it's implemented by the following example:

sequenceDiagram
    ServiceA->>+ServiceB: Hey, could you do this job for me?
    Note right of ServiceB: ServiceB does the job
    ServiceB->>+ServiceA: Sure, here is the data result
  1. ServiceA creates a callback queue that the response shall be sent to.
  2. ServiceA sends a json job message to an already declared queue on a rabbitmq server.
  3. ServiceB is listening on that queue for messages and spawns a new thread for each received.
  4. Once ServiceB has finished the work, using the received messages header it responds to the callback queue with the correlation-id.

Non-rpc

In bunbun-worker regular jobs are called non-rpc jobs, indicating that the response is not awaited.

Installation

Get directly from crates.io

[dependencies]
bunbun-worker = { version = "0.1.1" }

or get it directly from source

[dependencies]
bunbun-worker = { git = "https://git.4o1x5.dev/4o1x5/bunbun-worker", branch = "master" }

Usage

Here is a basic implementation of an RPC job in bunbun-worker

Limitations

  1. Currently some unwrap()'s are called inside the code and may results in panics (not in the job-runner).
  2. No settings, and very limited API
  3. The rabbitmq RPC logic is very basic with no message-versioning (aside using different queue names (eg service-class-v1.0.0) )

Bugs department

Since the code is hosted on a private git instance (as of right now) any bugs shall be discussed in 4o1x5's project room.

License

Licensed under GNU AFFERO GENERAL PUBLIC LICENSE

Contribution

Currently this library does not accept any contributors, as it's hosted on a private git server.

Credits

This package was made with the help of-