diff options
| author | Gaspard d'Hautefeuille <github@dhautefeuille.eu> | 2025-07-09 07:55:37 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-07-09 07:55:37 +0200 |
| commit | f798ddd4922d793d5e6ccb7c4111810d549ff4f4 (patch) | |
| tree | 223aa9d26deb176d983cd8e1bed51ff2cff71eff /searx/search/checker/scheduler.lua | |
| parent | bd593d0bad2189f57657bbcfa2c5e86f795c680e (diff) | |
[mod] migrate from Redis to Valkey (#4795)
This patch migrates from `redis==5.2.1` [1] to `valkey==6.1.0` [2].
The migration to valkey is necessary because the company behind Redis has decided
to abandon the open source license. After experiencing a drop in user numbers,
they now want to run it under a dual license again. But this move demonstrates
once again how unreliable the company is and how it treats open source
developers.
To review first, read the docs::
$ make docs.live
Follow the instructions to remove redis:
- http://0.0.0.0:8000/admin/settings/settings_redis.html
Config and install a local valkey DB:
- http://0.0.0.0:8000/admin/settings/settings_valkey.html
[1] https://pypi.org/project/redis/
[2] https://pypi.org/project/valkey/
Co-authored-by: HLFH <gaspard@dhautefeuille.eu>
Co-authored-by: Markus Heiser <markus.heiser@darmarit.de>
Diffstat (limited to 'searx/search/checker/scheduler.lua')
| -rw-r--r-- | searx/search/checker/scheduler.lua | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/searx/search/checker/scheduler.lua b/searx/search/checker/scheduler.lua index 0de9b404d..ec318ddd6 100644 --- a/searx/search/checker/scheduler.lua +++ b/searx/search/checker/scheduler.lua @@ -2,9 +2,9 @@ -- -- This script is not a string in scheduler.py, so editors can provide syntax highlighting. --- The Redis KEY is defined here and not in Python on purpose: +-- The Valkey KEY is defined here and not in Python on purpose: -- only this LUA script can read and update this key to avoid lock and concurrency issues. -local redis_key = 'SearXNG_checker_next_call_ts' +local valkey_key = 'SearXNG_checker_next_call_ts' local now = redis.call('TIME')[1] local start_after_from = ARGV[1] @@ -12,14 +12,14 @@ local start_after_to = ARGV[2] local every_from = ARGV[3] local every_to = ARGV[4] -local next_call_ts = redis.call('GET', redis_key) +local next_call_ts = redis.call('GET', valkey_key) if (next_call_ts == false or next_call_ts == nil) then - -- the scheduler has never run on this Redis instance, so: + -- the scheduler has never run on this Valkey instance, so: -- 1/ the scheduler does not run now -- 2/ the next call is a random time between start_after_from and start_after_to local initial_delay = math.random(start_after_from, start_after_to) - redis.call('SET', redis_key, now + initial_delay) + redis.call('SET', valkey_key, now + initial_delay) return { false, initial_delay } end @@ -31,6 +31,6 @@ if call_now then -- the checker runs now, define the timestamp of the next call: -- this is a random delay between every_from and every_to local periodic_delay = math.random(every_from, every_to) - next_call_ts = redis.call('INCRBY', redis_key, periodic_delay) + next_call_ts = redis.call('INCRBY', valkey_key, periodic_delay) end return { call_now, next_call_ts - now } |