Python 负载均衡,数据轮询 hash字符串 hashlib

在做数据分发轮询的时候遇到一个问题,我们并不只是想把数据依次分发到每台机器上,而是想根据每条数据的id来判断,同一个id的数据只放到同一个机器上,而不是可能随机出现在任何一台机器上。

1.使用python的hash()函数失败:
开始直接想使用hash发现同一字符串每次结果不一样,查了下是python为了安全做过处理,实验如下:

id = 'asghu263ff3'
print(hash(id))

执行两次:
结果:

2436877783843336617
-8819405633836300430

2.使用hashlib.sha1()完美解决:

id = 'asfgqwf2234f2d1421'
#一句代码搞定
hash_num = int(hashlib.sha1(id.encode('utf-8')).hexdigest(), 16) % (10 ** 8)

if hash_num%3 == 0:
    print("选择1号机器执行")
elif hash_num%3 == 1:
    print("选择2号机器执行")
else:
    print("选择3号机器执行")

猜你喜欢

转载自blog.csdn.net/weixin_44123540/article/details/119088336