Create asynchronous tasks from Python functions
Project description
ICIJ's async worker library
Installation
pip install icij-worker
Usage
Create an async app and register tasks
Create asynchronous task tailored for long running Python functions:
Given the following pure Python function inside the app.py
module:
def long_running_task(greeted: str) -> str:
greeting = f"Hello {greeted} !"
return greeting
decorate your function with ICIJApp
class and register a new task:
from icij_worker import AsyncApp
my_app = AsyncApp(name="my_app")
@my_app.task
def long_running_task(greeted: str) -> str:
greeting = f"Hello {greeted} !"
return greeting
this will register the long_running_task
function under the long_running_task
task name.
Optionally add progress handlers for a better task monitoring:
@my_app.task
def long_running_task(greeted: str, progress_handler: Callable[[float], None]) -> str:
progress_handler(0.0)
greeting = f"Hello {greeted} !"
progress_handler(100.0)
return greeting
Launch a async worker pool
Start a worker pool using:
icij-worker workers start "app.my_app"
provide worker pool options using:
icij-worker workers start -c worker_config.json -n 2 --backend multiprocessing "app.my_app"
depending on the worker configuration additional setup might be required.
Async worker implementations
Worker asynchronous backends
Implemented
- multiprocessing for CPU bound tasks
To be implemented
- asyncio for I/O bound tasks
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
icij_worker-0.4.5.tar.gz
(44.4 kB
view hashes)
Built Distribution
Close
Hashes for icij_worker-0.4.5-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c5ebce45e6fb1d2bd4a1d4abf56b951514ff14656d1f77de0181131e047a424a |
|
MD5 | 1d854b564b50804627ad0480e32c6871 |
|
BLAKE2b-256 | 6ab2cc8509916786d2a3bd9667fdb9e1d95dd8e0ccf95a87348447e9c6f58b9c |