在做数据分发轮询的时候遇到一个问题,我们并不只是想把数据依次分发到每台机器上,而是想根据每条数据的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号机器执行")