Redis Library¶
A collection of convenient functions and redis/lua scripts.
This code was partial inspired by the Bullet-Proofing Lua Scripts in RedisPy article.
- searx.redislib.LUA_SCRIPT_STORAGE = {}¶
- A global dictionary to cache client’s - Scriptobjects, used by- lua_script_storage
- searx.redislib.drop_counter(client, name)[source]¶
- Drop counter with redis key - SearXNG_counter_<name>- The replacement - <name>is a secret hash of the value from argument- name(see- incr_counter()and- incr_sliding_window()).
- searx.redislib.incr_counter(client, name: str, limit: int = 0, expire: int = 0)[source]¶
- Increment a counter and return the new value. - If counter with redis key - SearXNG_counter_<name>does not exists it is created with initial value 1 returned. The replacement- <name>is a secret hash of the value from argument- name(see- secret_hash()).- The implementation of the redis counter is the lua script from string - INCR_COUNTER.- Parameters:
- Returns:
- value of the incremented counter 
 - A simple demo of a counter with expire time and limit: - >>> for i in range(6): ... i, incr_counter(client, "foo", 3, 5) # max 3, duration 5 sec ... time.sleep(1) # from the third call on max has been reached ... (0, 1) (1, 2) (2, 3) (3, 3) (4, 3) (5, 1) 
- searx.redislib.incr_sliding_window(client, name: str, duration: int)[source]¶
- Increment a sliding-window counter and return the new value. - If counter with redis key - SearXNG_counter_<name>does not exists it is created with initial value 1 returned. The replacement- <name>is a secret hash of the value from argument- name(see- secret_hash()).- Parameters:
- name (str) – name of the counter 
- duration – live-time of the sliding window in seconds 
 
- Typeduration:
- int 
- Returns:
- value of the incremented counter 
 - The implementation of the redis counter is the lua script from string - INCR_SLIDING_WINDOW. The lua script uses sorted sets in Redis to implement a sliding window for the redis key- SearXNG_counter_<name>(ZADD). The current TIME is used to score the items in the sorted set and the time window is moved by removing items with a score lower current time minus duration time (ZREMRANGEBYSCORE).- The EXPIRE time (the duration of the sliding window) is refreshed on each call (incrementation) and if there is no call in this duration, the sorted set expires from the redis DB. - The return value is the amount of items in the sorted set (ZCOUNT), what means the number of calls in the sliding window. - A simple demo of the sliding window: - >>> for i in range(5): ... incr_sliding_window(client, "foo", 3) # duration 3 sec ... time.sleep(1) # from the third call (second) on the window is moved ... 1 2 3 3 3 >>> time.sleep(3) # wait until expire >>> incr_sliding_window(client, "foo", 3) 1 
- searx.redislib.lua_script_storage(client, script)[source]¶
- Returns a redis - Scriptinstance.- Due to performance reason the - Scriptobject is instantiated only once for a client (- client.register_script(..)) and is cached in- LUA_SCRIPT_STORAGE.
- searx.redislib.purge_by_prefix(client, prefix: str = 'SearXNG_')[source]¶
- Purge all keys with - prefixfrom database.- Queries all keys in the database by the given prefix and set expire time to zero. The default prefix will drop all keys which has been set by SearXNG (drops SearXNG schema entirely from database). - The implementation is the lua script from string - PURGE_BY_PREFIX. The lua script uses EXPIRE instead of DEL: if there are a lot keys to delete and/or their values are big, DEL could take more time and blocks the command loop while EXPIRE turns back immediate.- Parameters:
- prefix – prefix of the key to delete (default: - SearXNG_)