Fast and reliable distributed systems in Python
Project description
🌀 Portal
Fast and reliable distributed systems in Python.
Features
- 📡 Communication: Portal lets you bind functions to a
Server
and call them from one or moreClient
s. Wait on results viaFuture
objects. Clients can automatically restore broken connections. - 🚀 Performance: Optimized for throughput and latency. Array data is zero-copy serialized and deserialized for throughput near the hardware limit.
- 🤸 Flexibility: Function inputs and outputs can be nested dicts and lists
of numbers, strings, bytes, None values, and Numpy arrays. Bytes allow
applications to chose their own serialization, such as
pickle
. - 🚨 Error handlings: Provides
Process
andThread
objects that can reliably be killed by the parent. Unhandled exceptions in threads stop the program. Error files can be used to stop distributed systems. - 📦 Request batching: Use
BatchServer
to collect multiple incoming requests and process them at once, for example for AI inference servers. Batching and dispatching happens in a separate process to free the GIL. - ✅ Correctness: Covered by over 100 unit tests for common usage and edge cases and used for large scale distributed AI systems.
Installation
pip install portal
Example
This example runs the server and client in the same Python program using subprocesses, but they could also be separate Python scripts running on different machines.
def server():
import portal
server = portal.Server(2222)
server.bind('add', lambda x, y: x + y)
server.bind('greet', lambda msg: print('Message from client:', msg))
server.start()
def client():
import portal
client = portal.Client('localhost', 2222)
future = client.add(12, 42)
result = future.result()
print(result) # 54
client.greet('Hello World')
if __name__ == '__main__':
import portal
server_proc = portal.Process(server, start=True)
client_proc = portal.Process(client, start=True)
client_proc.join()
server_proc.kill()
print('Done')
Questions
Please open a separate GitHub issue for each question.
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
portal-3.5.1.tar.gz
(27.2 kB
view details)
File details
Details for the file portal-3.5.1.tar.gz
.
File metadata
- Download URL: portal-3.5.1.tar.gz
- Upload date:
- Size: 27.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9ec5c5433c397e9d7a35f56a1256363715c11f7d2d42c5e379ea02f0ba5cb544 |
|
MD5 | 14dc9bf6ee50bae008ed066454052999 |
|
BLAKE2b-256 | 41af6f0963667f3dc3171459ebf3e8e9d687631444340ec669e9c0f3f1580a83 |