【学习笔记】Bloom Filter(布隆过滤器)

布隆过滤器是一种高效的空间节省算法,用于判断元素是否存在于集合中。它利用多个哈希函数映射数据到位数组,误报率极低且节省空间。本文详细介绍了其工作原理、优势以及在实际场景中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

布隆过滤器(Bloom Filter)是1970年由布隆提出的。它实际上是一个很长的二进制向量和一系列随机映射函数。布隆过滤器可以用于检索一个元素是否在一个集合中。它的优点是空间效率和查询时间都远远超过一般的算法,缺点是有一定的误识别率和删除困难。Bloom filter的原理可以参考:维基百科【1】、论文【2】、网络文章【3】,还有文章【4】中有简单的程序实现。


我的总结:

1、Bloom Filter的原理非常简单,可以说是对Bit-map的扩展,Bit-map是用一个hash函数将数据映射到位数组的某一位,而Bloom Filter是用k个hash函数将数据映射到位数组的k位,检测时只有当k位都置为1才认为该数据存在;

2、Bloom Filter相对于Bit-map的优势。Bit-map实际上就是一个hash表,hash表的最常见的问题是地址冲突,文章【4】中提到“若要降低冲突发生的概率到1%,就要将BitSet的长度设置为URL个数的100倍。”,而Bloom Filter因为使用了多个hash函数,所以冲突的概率是非常低的,论文【2】中对Bloom Filter的错误概率进行了分析。总的来说,Bloom Filter出错概率要低,而且空间效率要高;

3、若位数组大小为m、加入的数据为n、哈希函数个数为k,文献【2】中证明了对于给定的m、n,当 k = ln(2)* m/n 时出错的概率是最小的;

4、Bloom Filter的特点:①不保存原始数据;②不能对插入的数据进行计数;③插入的数据是不能删除的,因为删除(即清除对应的k个bit位)会影响别的数据映射的bit位。相比之下,Bit-map是可以删除数据的(因为数据到bit位是一一对应的);

5、应用场合,由Bloom Filter的特点(不保存原始数据、无法计数、无法删除等)可知,非常适合于记录和查询某些数据是否“出现”过,例如网络爬虫为了避免重复爬取网页需要记录访问过的URL(文献【4】中列出并比较了该应用例子的不同方法),就可以将URL映射到Bloom Filter的位数组中。当然,适用Bloom Filter有一个前提——允许有一定的错误率!


参考文献:

【1】http://en.wikipedia.org/wiki/Bloom_filter
【2】http://pages.cs.wisc.edu/~cao/papers/summary-cache/node8.html
【3】http://blog.youkuaiyun.com/jiaomeng/article/details/1495500
【4】http://www.cnblogs.com/heaad/archive/2011/01/02/1924195.html

如今的大数据技术应用场景,对实时性的要求已经越来越高。作为新一代大数据流处理框架,由于非常好的实时性,Flink独树一帜,在近些年引起了业内极大的兴趣和关注。Flink能够提供毫秒级别的延迟,同时保证了数据处理的低延迟、高吞吐和结果的正确性,还提供了丰富的时间类型和窗口计算、Exactly-once 语义支持,另外还可以进行状态管理,并提供了CEP(复杂事件处理)的支持。Flink在实时分析领域的优势,使得越来越多的公司开始将实时项目向Flink迁移,其社区也在快速发展壮大。目前,Flink已经成为各大公司实时领域的发力重点,特别是国内以阿里为代表的一众大厂,都在全力投入,不少公司为Flink社区贡献了大量源码。如今Flink已被很多人认为是大数据实时处理的方向和未来,很多公司也都在招聘和储备了解掌握Flink的人才。本教程将Flink理论与电商数据分析项目实战并重,对Flink基础理论知识做了系统的梳理和阐述,并通过电商用户行为分析的具体项目用多个指标进行了实战演练。为有志于增加大数据项目经验、扩展流式处理框架知识的工程师提供了学习方式。二、教程内容和目标本教程主要分为两部分:第一部分,主要是Flink基础理论的讲解,涉及到各种重要概念、原理和API的用法,并且会有大量的示例代码实现;第二部分,以电商作为业务应用场景,以Flink作为分析框架,介绍一个电商用户行为分析项目的开发实战。通过理论和实际的紧密结合,可以使学员对Flink有充分的认识和理解,在项目实战中对Flink和流式处理应用的场景、以及电商分析业务领域有更深刻的认识;并且通过对流处理原理的学习和与批处理架构的对比,可以对大数据处理架构有更全面的了解,为日后成长为架构师打下基础。三、谁适合学1、有一定的 Java、Scala 基础,希望了解新的大数据方向的编程人员2、有 Java、Scala 开发经验,了解大数据相关知识,希望增加项目经验的开发人员3、有较好的大数据基础,希望掌握Flink及流式处理框架的求职人员
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值