redis.py 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import redis
  2. from datetime import timedelta
  3. class SyncRedisHelper:
  4. _pool: redis.ConnectionPool = None
  5. _instance = None
  6. def __init__(self):
  7. if not self._instance:
  8. self._pool = self._get_pool()
  9. self._instance = self
  10. def _get_pool(self) -> redis.ConnectionPool:
  11. if self._pool is None:
  12. self._pool = redis.ConnectionPool(
  13. # host="r-bp1mb0v08fqi4hjffu.redis.rds.aliyuncs.com", # 内网地址
  14. host="r-bp1mb0v08fqi4hjffupd.redis.rds.aliyuncs.com", # 外网地址
  15. port=6379,
  16. db=0,
  17. password="Wqsd@2019",
  18. # password="Qingqu2019",
  19. )
  20. return self._pool
  21. def get_client(self) -> redis.Redis:
  22. pool = self._get_pool()
  23. client = redis.Redis(connection_pool=pool)
  24. return client
  25. def close(self):
  26. if self._pool:
  27. self._pool.disconnect(inuse_connections=True)
  28. def get_data(name, data):
  29. key = f"task:{name}"
  30. helper = SyncRedisHelper()
  31. client = helper.get_client()
  32. if not client.exists('wangxueke-task'):
  33. acquire_lock = client.set('wangxueke-lock', 1, ex=600, nx=True)
  34. if not acquire_lock:
  35. return
  36. data = [{}, {}, {}]
  37. client.rpush('wangxueke-task', *data)
  38. return client.lpop('wangxueke-task')
  39. value = get_data('xiaoniangao', '1234857')
  40. if value is None:
  41. print("Value does not exist")
  42. else:
  43. print(f"Retrieved value: {value}")