Async reimplementation of nameko. First implementation will be built on AMQP with rabbitmq, however eventually the goal would be to support other broker types such as nats.io or kafka. HTTP endpoints will not be implemented in Basidia initially and the recommendation will be to create an API Gateway using a framework such as fastapi. This could change in the future however.
The goals for this project are to take the ideas presented by nameko and implement them with more modern technologies with async support and type hinting
- High Performance
- Easy to learn
- Easy to deploy
- Easy to test
- Modular
- Highly Extensible
- RPC and Events (pub-sub)
- CLI for easy and rapid development
- Utilities for unit and integration testing
- Extensible
An example hello world micro service
# Helloworld.py
class GreetingService:
name = "greeting_service"
@rpc
async def hello(self, name):
return f"Hello, {}!"
Running it from a shell:
$ basidia run Helloworld
starting services: greeting_service
And using the CLI to start the basidia shell and interact:
$ basidia shell
>>> b.rpc.greeting_service.hell(name="Brent")
'Hello, Brent!'
- Fork the repository
- Raise an issue or make a feature request
Apache 2.0. See LICENSE for details