core
Async Leaky Bucket Rate Limiter (predictable, queue-based version)
AsyncLeakyBucket
Async Leaky Bucket Rate Limiter - Queue-based implementation
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bucket_config
|
BucketConfig | None
|
Configuration for the leaky bucket with the max capacity and time period in seconds |
None
|
max_size
|
int
|
Maximum number of elements in the queue. A value of 0 means it can store infinite items |
0
|
Note
This implementation is synchronous and supports bursts up to the capacity within the specified time period
Source code in limitor/extra/leaky_bucket/core.py
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 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 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 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 | |
__aenter__()
async
__aexit__(exc_type, exc_val, exc_tb)
async
Exit the context manager, releasing any resources if necessary
acquire(amount=1.0, timeout=None)
async
Acquire capacity from the leaky bucket, waiting asynchronously until allowed.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
amount
|
float
|
The amount of capacity to acquire, defaults to 1 |
1.0
|
timeout
|
float | None
|
Optional timeout in seconds for the acquire operation |
None
|
Note
This is a producer
Source code in limitor/extra/leaky_bucket/core.py
capacity_info(amount=1)
Get the current capacity information of the leaky bucket
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
amount
|
float
|
The amount of capacity to check for, defaults to 1 |
1
|
Returns:
| Type | Description |
|---|---|
Capacity
|
A named tuple indicating if the bucket has enough capacity and how much more is needed |
Source code in limitor/extra/leaky_bucket/core.py
shutdown()
async
Gracefully shut down the worker task.