Web Messaging Protocol
Project description
almanet
Web Messaging Protocol is an open application level protocol that provides two messaging patterns:
- Routed Remote Procedure Calls (RPC)
- Produce & Consume
NSQ is a realtime distributed queue like message broker.
Almanet uses NSQ to exchange messages between different sessions.
Quick Start
Before install and run NSQD instance using this instruction.
Then install almanet
PyPI package
pip install almanet
or
poetry add almanet
Create a new file and
import almanet
Create your own Microservice
Explanation of the code that defines and runs a simple microservice
Define your instance of microservice
example_service = almanet.new_service(
"localhost:4150",
prefix="net.example"
)
Arguments:
- the TCP addresses of the NSQ instances
- prefix for the service's procedures, helping in identifying and organizing them
Define your custom exception
class denied(almanet.rpc_error):
"""Custom RPC exception"""
This custom exception can be raised within procedures to signal specific error conditions to the caller.
Define your remote procedure to call
@example_service.procedure
async def greeting(
session: almanet.Almanet,
payload: str,
) -> str:
"""Procedure that returns greeting message"""
if payload == "guest":
raise denied()
return f"Hello, {payload}!"
Decorator @example_service.procedure
registers the greeting
function as a remote procedure for the example_service
.
Arguments:
- payload is a data that was passed during invocation.
- session is a joined service, instance of
almanet.Almanet
It raises the custom denied exception, indicating that this payload is not allowed if payload
is "guest"
.
Otherwise, it returns a greeting message.
At the end of the file
if __name__ == "__main__":
example_service.serve()
Starts the service, making it ready to handle incoming RPC requests.
Finally
Run your module using the python command
Call your Microservice
Explanation of the code for creating a new session, calling a remote procedure, and handling potential exceptions during the invocation.
Create a new session
session = almanet.new_session("localhost:4150")
Arguments:
- the TCP addresses of the NSQ instances
Calling the Remote Procedure
async with session:
result = await session.call("net.example.greeting", "Aidar")
print(result.payload)
async with session
ensures that the session is properly managed and closed after use.
Calls the remote procedure net.example.greeting
with the payload "Aidar"
.
Raises TimeoutError
if procedure not found or request timed out.
result.payload
contains the result of the procedure execution.
Catching remote procedure exceptions
async with session:
try:
await session.call("net.example.greeting", "guest")
except almanet.rpc_error as e:
print("during call net.example.greeting('guest'):", e)
The try
block attempts to call the net.example.greeting
procedure with the payload "guest"
.
If an exception occurs during the call, specifically an almanet.rpc_error
,
it is caught by the except
block.
Finally
Run your module using the python command
See the full examples in ./examples
directory.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file almanet-0.3.2.tar.gz
.
File metadata
- Download URL: almanet-0.3.2.tar.gz
- Upload date:
- Size: 13.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.12.3 Darwin/22.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0020626dcfe88f46ecbcd82fcbf2649af784215d89da52993c6d3acaa0950510 |
|
MD5 | c2ca321a7e181107a80b1d06fa3e3a48 |
|
BLAKE2b-256 | db594ba8467dbba83f6d9131a2af1935fa05467f97b99a80476fba8e6bc810e1 |
File details
Details for the file almanet-0.3.2-py3-none-any.whl
.
File metadata
- Download URL: almanet-0.3.2-py3-none-any.whl
- Upload date:
- Size: 16.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.12.3 Darwin/22.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b9071a9f7141f85d0204f724435386bc107076bbbcdb82fb790ca3b4c9c1d7d5 |
|
MD5 | c6d3454d0c966bacce4a1ad0c974aa0b |
|
BLAKE2b-256 | 7f7c5a28b69ee9eaca560b3210fea9a63c486a2fc6608c15f07f28301b95586d |