pyrate_limiter.buckets package¶
Concrete bucket implementations
- class pyrate_limiter.buckets.InMemoryBucket(rates)¶
Bases:
AbstractBucketSimple In-memory Bucket using native list Clock can be either time.time or time.monotonic When leak, clock is required Pros: fast, safe, and precise Cons: since it resides in local memory, the data is not persistent, nor scalable Usecase: small applications, simple logic
- count()¶
Count number of items in the bucket
- Return type:
int
- flush()¶
Flush the whole bucket - Must remove failing-rate after flushing
- Return type:
None
- items¶
- leak(current_timestamp=None)¶
leaking bucket - removing items that are outdated
- Return type:
int
- peek(index)¶
Peek at the rate-item at a specific index in latest-to-earliest order NOTE: The reason we cannot peek from the start of the queue(earliest-to-latest) is we can’t really tell how many outdated items are still in the queue
- Return type:
RateItem|None
- put(item)¶
Put an item (typically the current time) in the bucket return true if successful, otherwise false
- Return type:
bool
- rates¶
- class pyrate_limiter.buckets.MultiprocessBucket(rates, items, mp_lock)¶
Bases:
InMemoryBucket- classmethod init(rates)¶
Creates a single ListProxy so that this bucket can be shared across multiple processes.
- items¶
- leak(current_timestamp=None)¶
leaking bucket - removing items that are outdated
- Return type:
int
- limiter_lock()¶
An additional lock to be used by Limiter in-front of the thread lock. Intended for multiprocessing environments where a thread lock is insufficient.
- mp_lock¶
- put(item)¶
Put an item (typically the current time) in the bucket return true if successful, otherwise false
- Return type:
bool
- rates¶
- class pyrate_limiter.buckets.PostgresBucket(pool, table, rates)¶
Bases:
AbstractBucket- close()¶
Release any resources held by the bucket.
Subclasses may override this method to perform any necessary cleanup (e.g., closing files, network connections, or releasing locks) when the bucket is no longer needed.
- count()¶
Count number of items in the bucket
- Return type:
Union[int,Awaitable[int]]
- flush()¶
Flush the whole bucket - Must remove failing-rate after flushing
- Return type:
Optional[Awaitable[None]]
- leak(current_timestamp=None)¶
leaking bucket - removing items that are outdated
- Return type:
Union[int,Awaitable[int]]
- peek(index)¶
Peek at the rate-item at a specific index in latest-to-earliest order NOTE: The reason we cannot peek from the start of the queue(earliest-to-latest) is we can’t really tell how many outdated items are still in the queue
- pool¶
- put(item)¶
Put an item (typically the current time) in the bucket return true if successful, otherwise false
- Return type:
Union[bool,Awaitable[bool]]
- rates¶
- table¶
- class pyrate_limiter.buckets.RedisBucket(rates, redis, bucket_key, script_hash)¶
Bases:
AbstractBucketA bucket using redis for storing data - We are not using redis’ built-in TIME since it is non-deterministic - In distributed context, use local server time or a remote time server - Each bucket instance use a dedicated connection to avoid race-condition - can be either sync or async
- bucket_key¶
- count()¶
Count number of items in the bucket
- flush()¶
Flush the whole bucket - Must remove failing-rate after flushing
- classmethod init(rates, redis, bucket_key)¶
- leak(current_timestamp=None)¶
leaking bucket - removing items that are outdated
- Return type:
Union[int,Awaitable[int]]
- now()¶
Retrieve current timestamp from the clock backend.
- peek(index)¶
Peek at the rate-item at a specific index in latest-to-earliest order NOTE: The reason we cannot peek from the start of the queue(earliest-to-latest) is we can’t really tell how many outdated items are still in the queue
- put(item)¶
Add item to key
- Return type:
Union[bool,Awaitable[bool]]
- rates¶
- redis¶
- script_hash¶
- class pyrate_limiter.buckets.SQLiteBucket(rates, conn, table, lock=None)¶
Bases:
AbstractBucketFor sqlite bucket, we are using the sql time function as the clock item’s timestamp wont matter here
- close()¶
Release any resources held by the bucket.
Subclasses may override this method to perform any necessary cleanup (e.g., closing files, network connections, or releasing locks) when the bucket is no longer needed.
- conn¶
- count()¶
Count number of items in the bucket
- Return type:
int
- flush()¶
Flush the whole bucket - Must remove failing-rate after flushing
- Return type:
None
- full_count_query¶
- classmethod init_from_file(rates, table='rate_bucket', db_path=None, create_new_table=True, use_file_lock=False)¶
- Return type:
- leak(current_timestamp=None)¶
Leaking/clean up bucket
- Return type:
int
- limiter_lock()¶
An additional lock to be used by Limiter in-front of the thread lock. Intended for multiprocessing environments where a thread lock is insufficient.
- lock¶
- now()¶
Retrieve current timestamp from the clock backend.
- peek(index)¶
Peek at the rate-item at a specific index in latest-to-earliest order NOTE: The reason we cannot peek from the start of the queue(earliest-to-latest) is we can’t really tell how many outdated items are still in the queue
- Return type:
Optional[RateItem]
- put(item)¶
Put an item (typically the current time) in the bucket return true if successful, otherwise false
- Return type:
bool
- rates¶
- table¶
- use_limiter_lock¶
- class pyrate_limiter.buckets.SQLiteClock(conn)¶
Bases:
AbstractClockGet timestamp using SQLite as remote clock backend
- __init__(conn)¶
In multiprocessing cases, use the bucket, so that a shared lock is used.
- classmethod default()¶
- lock¶
- now()¶
Get time as of now, in milliseconds
- Return type:
int
- time_query = "SELECT CAST(ROUND((julianday('now') - 2440587.5)*86400000) As INTEGER)"¶
Submodules¶
- pyrate_limiter.buckets.in_memory_bucket module
- pyrate_limiter.buckets.mp_bucket module
- pyrate_limiter.buckets.postgres module
- pyrate_limiter.buckets.redis_bucket module
- pyrate_limiter.buckets.sqlite_bucket module
QueriesSQLiteBucketSQLiteBucket.close()SQLiteBucket.connSQLiteBucket.count()SQLiteBucket.flush()SQLiteBucket.full_count_querySQLiteBucket.init_from_file()SQLiteBucket.leak()SQLiteBucket.limiter_lock()SQLiteBucket.lockSQLiteBucket.now()SQLiteBucket.peek()SQLiteBucket.put()SQLiteBucket.ratesSQLiteBucket.tableSQLiteBucket.use_limiter_lock
SQLiteClock