db.py 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. import redis
  2. from proxypool.error import PoolEmptyError
  3. from proxypool.setting import REDIS_HOST, REDIS_PORT, REDIS_PASSWORD, REDIS_KEY
  4. from proxypool.setting import MAX_SCORE, MIN_SCORE
  5. from random import choice
  6. class RedisClient(object):
  7. def __init__(self, host=REDIS_HOST, port=REDIS_PORT, password=REDIS_PASSWORD):
  8. """
  9. 初始化
  10. :param host:
  11. :param port:
  12. :param password:
  13. """
  14. self.db = redis.StrictRedis(host=host, port=port, password=password)
  15. def top(self):
  16. """
  17. 获取排名第一的代理
  18. :return:
  19. """
  20. proxies = self.db.zrevrange(REDIS_KEY, 0, 0)
  21. if proxies:
  22. return proxies[0].decode('utf-8')
  23. else:
  24. raise PoolEmptyError
  25. def add(self, proxy, score=MAX_SCORE):
  26. """
  27. 添加代理,设置分数为最高
  28. :param proxy:
  29. :param score:
  30. :return:
  31. """
  32. return self.db.zadd(REDIS_KEY, score, proxy)
  33. def random(self):
  34. """
  35. 随机获取有效代理,首先尝试获取最高分数代理,如果不存在,按照排名获取,否则异常
  36. :return:
  37. """
  38. result = self.db.zrangebyscore(REDIS_KEY, MAX_SCORE, MAX_SCORE)
  39. if len(result):
  40. return choice(result).decode('utf-8')
  41. else:
  42. result = self.db.zrevrange(REDIS_KEY, 0, 100)
  43. if len(result):
  44. return choice(result).decode('utf-8')
  45. else:
  46. raise PoolEmptyError
  47. def decrease(self, proxy):
  48. """
  49. 代理值减一分,小于最小值则删除
  50. :param proxy:
  51. :return:
  52. """
  53. score = self.db.zscore(REDIS_KEY, proxy)
  54. if score and score > MIN_SCORE:
  55. self.db.zincrby(REDIS_KEY, proxy, -1)
  56. print('代理', proxy, '当前分数', score, '减1')
  57. else:
  58. self.db.zrem(REDIS_KEY, proxy)
  59. print('代理', proxy, '当前分数', score, '移除')
  60. def exists(self, proxy):
  61. """
  62. 判断是否存在
  63. :param proxy:
  64. :return:
  65. """
  66. return not self.db.zscore(REDIS_KEY, proxy) == None
  67. def max(self, proxy):
  68. """
  69. 将代理设置为MAX_SCORE
  70. :param proxy:
  71. :return:
  72. """
  73. return self.db.zadd(REDIS_KEY, MAX_SCORE, proxy)
  74. def count(self):
  75. """
  76. 获取数量
  77. :return:
  78. """
  79. return self.db.zcard(REDIS_KEY)
  80. def all(self):
  81. """
  82. 获取全部代理
  83. :return:
  84. """
  85. all = self.db.zrangebyscore(REDIS_KEY, MIN_SCORE, MAX_SCORE)
  86. return [item.decode('utf-8') for item in all]
  87. if __name__ == '__main__':
  88. conn = RedisClient()
  89. result = conn.all()
  90. print(result)
  91. random = conn.random()
  92. print('Random', random)
  93. top = conn.top()
  94. print('Top', top)
  95. conn.decrease('a')