redis布隆过滤器
首页->学习资料->微服务治理->redis 关键词: 发布时间:2018-06-14 14:31:11 浏览次数:2058

【redis布隆过滤器】

针对的问题,如:

在50亿个电话号码中,准确且快速判断某10万个电话号码是否存在于其中

垃圾邮件过滤

单词拼写检查

解决方法:

mysql:慢,

HypeLogLog:内存使用量比较大,误差大

布隆过滤器:误差小,相对较快

原理:

结合bitmap(它提供一个最大长度为512MB(2^32)的位数组),产生一个很长的位图,将50亿个电话号码中的每一个经过多个hash函数计算,

将得到的某个位置标记为1;然后将10万个中的某个电话通过相同的hash函数计算得到的

位置与bigmap中的数据进行比较,如果相等则表示存在,否则不存在;这个也是有可能产生误差的,但比HyperLogLog误差小得多

https://blog.csdn.net/qq_30242609/article/details/71024458

https://blog.csdn.net/NEWCIH/article/details/78934420


https://blog.csdn.net/justdoithai/article/details/51233082



由图中可以看出布隆过滤器不能判断一个值 是否一定存在于其中,但可以判断一定不存在其中;

由于某个位置可能共用,所以不能删除布隆过滤器的数据


image.png

赞:(0)
踩:(0)
相关文章
redis数据持久化
memcache与redis比较
redis数据类型及常用命令
redis慢查询
redis pipeline
redis 发布与订阅
redis位图bitmap
redis HyperLogLog
redis geo
redis消息队列实例
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:607篇
浏览数:933078
粤ICP备18028092号-1  微信:hurong241