1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- # SPDX-License-Identifier: AGPL-3.0-or-later
- # lint: pylint
- """Implementation of the redis client (redis-py_).
- .. _redis-py: https://github.com/redis/redis-py
- This implementation uses the :ref:`settings redis` setup from ``settings.yml``.
- A redis DB connect can be tested by::
- >>> from searx.shared import redisdb
- >>> redisdb.init()
- True
- >>> db = redisdb.client()
- >>> db.set("foo", "bar")
- True
- >>> db.get("foo")
- b'bar'
- >>>
- """
- import logging
- import redis
- from searx import get_setting
- logger = logging.getLogger('searx.shared.redis')
- _client = None
- def client():
- global _client # pylint: disable=global-statement
- if _client is None:
- # not thread safe: in the worst case scenario, two or more clients are
- # initialized only one is kept, the others are garbage collected.
- _client = redis.Redis.from_url(get_setting('redis.url'))
- return _client
- def init():
- try:
- c = client()
- logger.info("connected redis DB --> %s", c.acl_whoami())
- return True
- except redis.exceptions.ConnectionError as exc:
- logger.error("can't connet redis DB ...")
- logger.error(" %s", exc)
- return False
|