布隆过滤器概念及其公式推导 刺骨的言语ヽ痛彻心扉 2022-01-29 09:25 299阅读 0赞 ### 布隆过滤器概念及其公式推导 ### * 布隆过滤器概念 * * 数据如何存入布隆过滤器 * 误判情况 * 实际应用面试题 * 公式推导 * * 误判概率即失误率的证明和计算 * 其他使用场景 公式推导内容转自博客 [https://blog.csdn.net/houzuoxin/article/details/20907911][https_blog.csdn.net_houzuoxin_article_details_20907911] # 布隆过滤器概念 # ## 数据如何存入布隆过滤器 ## **布隆过滤器是由一个很长的二进制矢量和一系列哈希函数组成的。** **二进制矢量本质是一个位数组**:数组的每个元素都只占1bit空间,并且每个元素只能为0或1。 **布隆过滤器还拥有k个哈希函数**,当一个元素加入布隆过滤器中的时候,会使用k个哈希函数对其进行k次计算,得到k个哈希值,并且根据得到的哈希值,在维数组中把对应下标的值置位1。 **若要判断这个数是否在布隆过滤器中,就对该元素进行k次哈希计算,得到的值在位数组中判断每个元素是否都为1,如果每个元素都为1,就说明这个值在布隆过滤器中。** ## 误判情况 ## **布隆过滤器只能插入不能删除**,所以插入的元素越来越多时,当一个不在布隆过滤器中的元素,经过同样规则的哈希计算之后,得到的值在位数组中查询,有可能这些位置因为其他的元素先被置1了。所以布隆过滤器存在误判的情况,但是如果布隆过滤器判断某个元素不在布隆过滤器中,那么这个值就一定不在。 **如何补救这个情况呢,可以设立白名单,存储可能会被误判的元素。** **综上所述,布隆过滤器可精确的代表一个集合,可精确判断某一元素是否在此集合中,精确程度由用户的具体设计决定,达到100%的正确是不可能的。但是布隆过滤器的优势在于,利用很少的空间可以达到较高的精确率。** # 实际应用面试题 # 不安全网页的黑名单包含100亿个黑名单网页,每个网页的URL最多占用64字节。现在想要实现一种网页过滤系统,可以根据网页的URL判断该网站是否在黑名单上,请设计该系统。要求该系统允许有万分之一以下的判断失误率,并且使用的额外空间不要超过30G。 **解题:布隆过滤器的bitarray大小如何确定?** * 设bitarray大小为m,样本数量为n,失误率为p。 * 由题可知 n = 100亿,p = 0.01% * 单个样本大小不影响布隆过滤器大小,因为样本会通过哈希函数得到输出值。 * 使用样本数量n和失误率p可以算出m,公式为: * ![公式][20190521165248851.png] * 求得 m = 19.19n,向上取整为 20n。所以2000亿bit,约为25G。 * 所使用哈希函数个数k可以由以下公式求得: * ![公式][2019052116540727.png] * 所以 k = 14,即需要14个哈希函数。 * 通过 m = 20n, k = 14,可以通过以下公式算出设计的布隆过滤器的真实失误率为0.006%。 * ![公式][20190521165657494.png] # 公式推导 # 上面那些公式是怎么来的呢,很多地方都只写明了公式,但是没有解释公式怎么推导出来的。最终终于找到一个大佬写的很详细的推导过程,绝对看得懂,转自https://blog.csdn.net/houzuoxin/article/details/20907911,但是为了方便自己后续复习,所以现在将推导过程截图贴置这里,做一个大佬的搬运工。 ## 误判概率即失误率的证明和计算 ## **下面的图中红色框里,你可以看到 布隆过滤器长度m、误判率p 以及 哈希函数个数k 的求解过程。** ![图1][1] ![图][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2dhb3l1ZWFjZQ_size_16_color_FFFFFF_t_70] ![图3][3] ![图][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2dhb3l1ZWFjZQ_size_16_color_FFFFFF_t_70 1] # 其他使用场景 # * **网页爬虫对URL的去重**,避免爬去相同的URL地址 * **垃圾邮件过滤**,从数十亿个垃圾邮件列表中判断某邮箱是否是杀垃圾邮箱 * **解决数据库缓存击穿**,黑客攻击服务器时,会构建大量不存在于缓存中的key向服务器发起请求,在数据量足够大的时候,频繁的数据库查询会导致挂机。 [https_blog.csdn.net_houzuoxin_article_details_20907911]: https://blog.csdn.net/houzuoxin/article/details/20907911 [20190521165248851.png]: /images/20220129/34bbb1b9e6684a4ba9ab5eaee4ede0a5.png [2019052116540727.png]: /images/20220129/724fac0a40b845b982a887d64cf16e1c.png [20190521165657494.png]: /images/20220129/b60312ce6d0f4feaa416f39e17dbb051.png [1]: /images/20220129/02b390f037b84cfabc9b50c99f1f94ff.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2dhb3l1ZWFjZQ_size_16_color_FFFFFF_t_70]: /images/20220129/6350b54a7358404fa33812bef62c397a.png [3]: /images/20220129/a332b676296846b397c8fa1975bcb712.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2dhb3l1ZWFjZQ_size_16_color_FFFFFF_t_70 1]: /images/20220129/aac09dddf4274dfb925f876bb47056cb.png
相关 布隆过滤器 - Redis 布隆过滤器,Guava 布隆过滤器 BloomFilter - 代码实践 文章目录 布隆过滤器 - Redis 布隆过滤器,Guava 布隆过滤器 BloomFilter - 代码实践 1、通过guava 实现的布 ゝ一世哀愁。/ 2023年10月09日 04:22/ 0 赞/ 130 阅读
相关 布隆过滤器 布隆过滤器 什么是布隆过滤器? 布隆过滤器(Bloom Filter)是1970年由布隆提出的。它实际上是一个很长的`二进制向量`和`一系列随机映射函数`。布 古城微笑少年丶/ 2022年10月15日 12:53/ 0 赞/ 282 阅读
相关 布隆过滤器 > 布隆过滤器\[1\](Bloom Filter)是由布隆在1970年提出的。它实际上是由一个很长的二进制向量和一系列随机映射函数组成,布隆过滤器可以用于检索一个元素是否在一 r囧r小猫/ 2022年07月14日 13:15/ 0 赞/ 259 阅读
相关 布隆过滤器 布隆过滤器实际上就是哈希和位图的结合 它的优点:速度快并且节省空间 它的缺点:存在误判(比如存在不同的字符串可能存在相同的ASCII,这样我们在判断的时候就会出现误判) 末蓝、/ 2022年06月12日 22:14/ 0 赞/ 326 阅读
相关 布隆过滤器 布隆过滤器原理 布隆过滤器有什么用? 布隆过滤器是可以用于判断一个元素是不是在一个集合里,并且相比于其它的数据结构,布隆过滤器在空间和时间方面都有巨大的优势。 特 系统管理员/ 2022年03月25日 07:37/ 0 赞/ 326 阅读
相关 布隆过滤器 使用场景 ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4u 缺乏、安全感/ 2022年03月01日 11:28/ 0 赞/ 341 阅读
相关 布隆过滤器概念及其公式推导 布隆过滤器概念及其公式推导 布隆过滤器概念 数据如何存入布隆过滤器 误判情况 实际应用面试题 公式推导 误判概率即 刺骨的言语ヽ痛彻心扉/ 2022年01月29日 09:25/ 0 赞/ 300 阅读
相关 布隆过滤器 布隆过滤器介绍 > 布隆过滤器在wiki上的介绍: 布隆过滤器(Bloom Filter)是1970年由布隆提出的。它实际上是一个很长的二进制向量和一系列随机映射函数。布 喜欢ヅ旅行/ 2021年12月16日 01:01/ 0 赞/ 400 阅读
相关 布隆过滤器 布隆过滤器常常被用来检测某个元素是否是巨量数据集合中的成员 1、基本原理: (1)将长度为m的位数组元素全部置为0; (2)对集合S中的某个成员a,分别用k个哈希函数对其 亦凉/ 2021年12月15日 12:59/ 0 赞/ 420 阅读
相关 布隆过滤器 布隆过滤器 前言 布隆过滤器原理 布隆过滤器优缺点 优点 缺点 使用场景 前言 Hash(散列)函数在计算机 本是古典 何须时尚/ 2021年11月04日 13:34/ 0 赞/ 458 阅读
还没有评论,来说两句吧...