prefect.concurrency.sync
concurrency(names, occupy=1, timeout_seconds=None, create_if_missing=True, max_retries=None)
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 sync concurrency
context manager:
from prefect.concurrency.sync import concurrency
def resource_heavy():
with concurrency("test", occupy=1):
print("Resource heavy task")
def main():
resource_heavy()
Source code in src/prefect/concurrency/sync.py
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 |
|
rate_limit(names, occupy=1, timeout_seconds=None, create_if_missing=True)
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/sync.py
103 104 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 |
|