prefect.concurrency.asyncio
AcquireConcurrencySlotTimeoutError
Bases: TimeoutError
Raised when acquiring a concurrency slot times out.
Source code in src/prefect/concurrency/asyncio.py
30 31 |
|
ConcurrencySlotAcquisitionError
Bases: Exception
Raised when an unhandlable occurs while acquiring concurrency slots.
Source code in src/prefect/concurrency/asyncio.py
26 27 |
|
concurrency(names, occupy=1, timeout_seconds=None, create_if_missing=True, max_retries=None)
async
A context manager that acquires and releases concurrency slots from the given concurrency limits.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
names |
Union[str, List[str]]
|
The names of the concurrency limits to acquire slots from. |
required |
occupy |
int
|
The number of slots to acquire and hold from each limit. |
1
|
timeout_seconds |
Optional[float]
|
The number of seconds to wait for the slots to be acquired before
raising a |
None
|
create_if_missing |
bool
|
Whether to create the concurrency limits if they do not exist. |
True
|
max_retries |
Optional[int]
|
The maximum number of retries to acquire the concurrency slots. |
None
|
Raises:
Type | Description |
---|---|
TimeoutError
|
If the slots are not acquired within the given timeout. |
A simple example of using the async concurrency
context manager:
from prefect.concurrency.asyncio import concurrency
async def resource_heavy():
async with concurrency("test", occupy=1):
print("Resource heavy task")
async def main():
await resource_heavy()
Source code in src/prefect/concurrency/asyncio.py
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 |
|
rate_limit(names, occupy=1, timeout_seconds=None, create_if_missing=True)
async
Block execution until an occupy
number of slots of the concurrency
limits given in names
are acquired. Requires that all given concurrency
limits have a slot decay.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
names |
Union[str, List[str]]
|
The names of the concurrency limits to acquire slots from. |
required |
occupy |
int
|
The number of slots to acquire and hold from each limit. |
1
|
timeout_seconds |
Optional[float]
|
The number of seconds to wait for the slots to be acquired before
raising a |
None
|
create_if_missing |
Optional[bool]
|
Whether to create the concurrency limits if they do not exist. |
True
|
Source code in src/prefect/concurrency/asyncio.py
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 |
|