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号机器执行")
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值