redis.py 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. import json
  2. import redis
  3. from common.odps_data import OdpsDataCount
  4. class SyncRedisHelper:
  5. _pool: redis.ConnectionPool = None
  6. _instance = None
  7. def __init__(self):
  8. if not self._instance:
  9. self._pool = self._get_pool()
  10. self._instance = self
  11. def _get_pool(self) -> redis.ConnectionPool:
  12. if self._pool is None:
  13. self._pool = redis.ConnectionPool(
  14. # host="r-bp1mb0v08fqi4hjffupd.redis.rds.aliyuncs.com", # 外网地址
  15. host="r-bp1mb0v08fqi4hjffu.redis.rds.aliyuncs.com", # 内网地址
  16. port=6379,
  17. db=0,
  18. password="Wqsd@2019",
  19. # password="Qingqu2019",
  20. )
  21. return self._pool
  22. def get_client(self) -> redis.Redis:
  23. pool = self._get_pool()
  24. client = redis.Redis(connection_pool=pool)
  25. return client
  26. def close(self):
  27. if self._pool:
  28. self._pool.disconnect(inuse_connections=True)
  29. def install_video_data(dt, redis_task, table_name):
  30. """写入redis需要打标签的视频"""
  31. data = OdpsDataCount.main(table_name, dt)
  32. if not data:
  33. return
  34. # task = f"task:video_ai"
  35. helper = SyncRedisHelper()
  36. client = helper.get_client()
  37. client.rpush(redis_task, *data)
  38. def get_video_data(redis_task):
  39. """获取一条需要打标签的视频"""
  40. # task = redis_task
  41. helper = SyncRedisHelper()
  42. client = helper.get_client()
  43. ret = client.rpop(redis_task)
  44. return ret
  45. def in_video_data(ret):
  46. """分析失败视频重新写入redis"""
  47. task = f"task:video_ai"
  48. helper = SyncRedisHelper()
  49. client = helper.get_client()
  50. client.rpush(task, ret)