海量数据处理之什么是Bloom Filter

运维 数据库运维
Bloom Filter是一种空间效率很高的随机数据结构,它利用位数组很简洁地表示一个集合,并能判断一个元素是否属于这个集合。

【什么是Bloom Filter】

Bloom Filter是一种空间效率很高的随机数据结构,它利用位数组很简洁地表示一个集合,并能判断一个元素是否属于这个集合。Bloom Filter的这种高效是有一定代价的:在判断一个元素是否属于某个集合时,有可能会把不属于这个集合的元素误认为属于这个集合(false positive)。因此,Bloom Filter不适合那些“零错误”的应用场合。而在能容忍低错误率的应用场合下,Bloom Filter通过极少的错误换取了存储空间的极大节省。 这里有一篇关于Bloom Filter的详细介绍,不太懂的博友可以看看。

【适用范围】

可以用来实现数据字典,进行数据的判重,或者集合求交集

【基本原理及要点】

对于原理来说很简单,位数组+k个独立hash函数。将hash函数对应的值的位数组置1,查找时如果发现所有hash函数对应位都是1说明存在,很明显这 个过程并不保证查找的结果是100%正确的。同时也不支持删除一个已经插入的关键字,因为该关键字对应的位会牵动到其他的关键字。所以一个简单的改进就是 counting Bloom filter,用一个counter数组代替位数组,就可以支持删除了。

还有一个比较重要的问题,如 何根据输入元素个数n,确定位数组m的大小及hash函数个数。当hash函数个数k=(ln2)*(m/n)时错误率最小。在错误率不大于E的情况 下,m至少要等于n*lg(1/E)才能表示任意n个元素的集合。但m还应该更大些,因为还要保证bit数组里至少一半为0,则m应 该>=nlg(1/E)*lge 大概就是nlg(1/E)1.44倍(lg表示以2为底的对数)。

举个例子我们假设错误率为0.01,则此时m应大概是n的13倍。这样k大概是8个。

注意这里m与n的单位不同,m是bit为单位,而n则是以元素个数为单位(准确的说是不同元素的个数)。通常单个元素的长度都是有很多bit的。所以使用bloom filter内存上通常都是节省的。

【扩展】

Bloom filter将集合中的元素映射到位数组中,用k(k为哈希函数个数)个映射位是否全1表示元素在不在这个集合中。Counting bloom filter(CBF)将位数组中的每一位扩展为一个counter,从而支持了元素的删除操作。Spectral Bloom Filter(SBF)将其与集合元素的出现次数关联。SBF采用counter中的最小值来近似表示元素的出现频率。

【问题实例】

给你A,B两个文件,各存放50亿条URL,每条URL占用64字节,内存限制是4G,让你找出A,B文件共同的URL。如果是三个乃至n个文件呢?

根据这个问题我们来计算下内存的占用,4G=2^32大概是40亿*8大概是340亿,n=50亿,如果按出错率0.01算需要的大概是650亿个 bit。 现在可用的是340亿,相差并不多,这样可能会使出错率上升些。另外如果这些urlip是一一对应的,就可以转换成ip,则大大简单了。

原文链接:http://blog.redfox66.com/post/2010/09/24/mass-data-topic-2-bloom-filter.aspx

【编辑推荐】

  1. 应对海量数据 Oracle数据库机青睐至强
  2. 淘宝海量数据库之克服随机IO难题
  3. Oceanbase一个千亿级海量数据库
责任编辑:艾婧 来源: 码农之家
相关推荐

2012-06-26 10:03:06

海量数据处理

2011-08-19 13:28:25

海量数据索引优化

2012-02-22 15:32:11

海量数据

2023-11-29 13:56:00

数据技巧

2024-02-07 09:25:52

数据处理快手大模型

2024-06-19 21:12:02

2023-10-05 12:43:48

数据处理

2023-05-08 14:49:54

数据处理DPU

2010-09-06 09:24:56

网格数据库

2024-02-22 10:14:40

Filter函数Python

2017-10-18 13:31:56

存储超融合架构数据中心

2016-06-16 10:52:25

IBM

2022-06-28 13:41:43

京东数据处理

2019-08-19 18:42:43

大数据海量数据

2013-10-12 16:53:46

SAP

2018-11-23 17:33:42

阿里云SQL Server 集群版

2019-06-12 16:21:52

时间序列PythonPandas

2022-08-26 05:18:30

分布式系统数据处理

2011-08-18 10:20:26

云计算国家统计局大数据
点赞
收藏

51CTO技术栈公众号