md5 - 将整个哈希范围拆分为 n 个相等的范围

标签 md5 hash sha1

我正在寻找一个散列范围(md5 或 sha1)并将其分成 n 个相等的范围。

例如,如果 m (num nodes) = 5,则整个哈希范围将被 5 分割,以便键范围分布均匀。我希望 n=1(节点 1)从哈希范围的开头到 1/5,从 1/5 到 2/5 的 2,一直到最后。

基本上,我需要将键范围映射到每个 n,这样当我散列一个值时,它知道哪个 n 将处理该范围。

我是散列的新手,有点不确定我可以从哪里开始为项目解决这个问题。你能提供的任何帮助都会很棒。

最佳答案

如果您希望将哈希值均匀地放入多个“桶”中,那么一些简单的数学运算就可以解决问题。注意四舍五入的边缘情况...您最好使用 2 的幂作为 BUCKETS 值。

顺便说一下,这是python代码,它支持大整数......

BUCKETS    = 5
BITS       = 160

BUCKETSIZE = 2**BITS / BUCKETS

int('ad01c5b3de58a02a42367e33f5bdb182d5e7e164', 16) / BUCKETSIZE == 3
int('553ae7da92f5505a92bbb8c9d47be76ab9f65bc2', 16) / BUCKETSIZE == 1
int('001c7c8c5ff152f1cc8ed30421e02a898cfcfb23', 16) / BUCKETSIZE == 0

关于md5 - 将整个哈希范围拆分为 n 个相等的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2706033/

相关文章:

drupal - 如何为 drupal 7 创建加密的哈希密码

javascript - 如何从 javascript 客户端验证 azure blob 存储 md5 哈希值?

performance - 如何加快大哈希表在磁盘上的随机访问操作

javascript - 使用 javascript 创建随机 sha1 盐

hash - 将要散列的最大字符串长度是多少?

c - 跟踪 Mhash 文件(散列)

encoding - Blackberry 编码 MD5 与 C# 中的 MD5 不同

hash - 为什么要吃好盐?

algorithm - 给定一个对象 A 和一个对象列表 L,如何在不测试所有情况的情况下找出 L 上的哪些对象是 A 的克隆?

md5 - 我应该使用什么校验和算法?