db.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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, INITIAL_SCORE
  5. from random import choice
  6. import re
  7. class RedisClient(object):
  8. def __init__(self, host=REDIS_HOST, port=REDIS_PORT, password=REDIS_PASSWORD):
  9. """
  10. 初始化
  11. :param host: Redis 地址
  12. :param port: Redis 端口
  13. :param password: Redis密码
  14. """
  15. self.db = redis.StrictRedis(host=host, port=port, password=password, decode_responses=True)
  16. def add(self, proxy, score=INITIAL_SCORE):
  17. """
  18. 添加代理,设置分数为最高
  19. :param proxy: 代理
  20. :param score: 分数
  21. :return: 添加结果
  22. """
  23. if not re.match('\d+\.\d+\.\d+\.\d+\:\d+', proxy):
  24. print('代理不符合规范', proxy, '丢弃')
  25. return
  26. if not self.db.zscore(REDIS_KEY, proxy):
  27. #return self.db.zadd(REDIS_KEY, score, proxy)
  28. #更新为redis3.0+版本,解决redis3.0更新后的报错,如用旧版本还原上方代码
  29. return self.db.zadd(REDIS_KEY, {proxy:score})
  30. def random(self):
  31. """
  32. 随机获取有效代理,首先尝试获取最高分数代理,如果不存在,按照排名获取,否则异常
  33. :return: 随机代理
  34. """
  35. result = self.db.zrangebyscore(REDIS_KEY, MAX_SCORE, MAX_SCORE)
  36. if len(result):
  37. return choice(result)
  38. else:
  39. result = self.db.zrevrange(REDIS_KEY, 0, 100)
  40. if len(result):
  41. return choice(result)
  42. else:
  43. raise PoolEmptyError
  44. def decrease(self, proxy):
  45. """
  46. 代理值减一分,小于最小值则删除
  47. :param proxy: 代理
  48. :return: 修改后的代理分数
  49. """
  50. score = self.db.zscore(REDIS_KEY, proxy)
  51. if score and score > MIN_SCORE:
  52. print('代理', proxy, '当前分数', score, '减1')
  53. #return self.db.zincrby(REDIS_KEY, proxy, -1)
  54. #更新为redis3.0+版本,解决redis3.0更新后的报错,如用旧版本还原上方代码
  55. return self.db.zincrby(REDIS_KEY, -1, proxy)
  56. else:
  57. print('代理', proxy, '当前分数', score, '移除')
  58. return self.db.zrem(REDIS_KEY, proxy)
  59. def exists(self, proxy):
  60. """
  61. 判断是否存在
  62. :param proxy: 代理
  63. :return: 是否存在
  64. """
  65. return not self.db.zscore(REDIS_KEY, proxy) == None
  66. def max(self, proxy):
  67. """
  68. 将代理设置为MAX_SCORE
  69. :param proxy: 代理
  70. :return: 设置结果
  71. """
  72. print('代理', proxy, '可用,设置为', MAX_SCORE)
  73. #return self.db.zadd(REDIS_KEY, MAX_SCORE, proxy)
  74. #更新为redis3.0+版本,解决redis3.0更新后的报错,如用旧版本还原上方代码
  75. return self.db.zadd(REDIS_KEY, {proxy:MAX_SCORE})
  76. def count(self):
  77. """
  78. 获取数量
  79. :return: 数量
  80. """
  81. return self.db.zcard(REDIS_KEY)
  82. def all(self):
  83. """
  84. 获取全部代理
  85. :return: 全部代理列表
  86. """
  87. return self.db.zrangebyscore(REDIS_KEY, MIN_SCORE, MAX_SCORE)
  88. def batch(self, start, stop):
  89. """
  90. 批量获取
  91. :param start: 开始索引
  92. :param stop: 结束索引
  93. :return: 代理列表
  94. """
  95. return self.db.zrevrange(REDIS_KEY, start, stop - 1)
  96. if __name__ == '__main__':
  97. conn = RedisClient()
  98. result = conn.batch(680, 688)
  99. print(result)