布隆过滤器实战

一、背景

本篇文章以解决实际需求的问题的角度进行切入,探讨了如果使用布隆过滤器快速丢弃无效请求,降低了系统的负载以及不必要的流量。

我们都知道布隆过滤器是以占用内存小,同时也能够实现快速的过滤从而满足我们的需求,本篇文章就不仔细展开说明布隆过滤器的工作原理,具体工作原理可以参考下面这篇博客。

Redis布隆过滤器的原理和应用场景,解决缓存穿透 - 知乎

二、实际要解决的问题

面临问题:在我们的日常工作中,我们通常是负责某个系统,例如订单系统、预约系统、保险系统等等,在一整个业务流程中,我们只是负责某一业务系统,我们都会有自己的上下游,以预约系统为例,订单系统(下游)根据预约单号查询预约系统是否有预约,从而处理对应逻辑,但并不是所有的订单都是有预约的,大部分的订单是没有的,对于我预约系统来说,订单系统大部分的查询都是无效的,但是如果我只是使用数据库的前提下,大部分的请求还是打到了我的数据库,如图所示

这种情况下,如果订单系统的请求量非常大,那对我们预约的系统压力以及数据库的压力会比较大,那么我们将如何解决我们的系统压力以及数据库的压力呢?

三、解决方案

刚才说到,订单系统有大量的订单,但是不是每个订单都需要预约,大部分单号对预约系统来说都是无效的请求,所以这个业务场景我们就可以考虑用布隆过滤器对无效的请求进行过滤。

具体怎么做呢,我们可以在数据库和预约系统之间增加布隆过滤器,增加了布隆过滤器那同时也必须增加布隆过滤器的数据初始化。我们可以这样设计,如下图所示

  • 在数据流入的时候增加布隆布隆过滤器的写入

        关键代码:BloomFilterUtils.addValue

/**
     * @author chen
     * @description 下单后处理
     * @param orderNo 订单号
     * @date: 2024/3/3 9:42
     */
    private void afterOrderHandle(String orderNo) {
        //redisTemplate.opsForValue().setBit("test-key",10,true);
        //通过这种方式实现,需要自己使用hash算法计算对应位数组下标位置(不推荐)
        //推荐使用redisson开箱即用的RBloomFilter
        //加载到布隆过滤器
        BloomFilterUtils.addValue(BloomFilterEnum.TB_ORDER_BLOOM_FILTER.getBloomFilterName(),orderNo);
        log.info("#加载完毕#");
        //其他操作.....
    }
  • 在下游订单系统查询预约系统时增加通过订单号查询布隆过滤器进行过滤,能够快速的对上游请求进行快速过滤

关键代码:BloomFilterUtils.isContains

/**
     * @author chen
     * @description 订单查询
     * @param reqVO 请求入参
     * @date: 2024/3/3 9:59
     * @return com.redis.bloom.filter.data.vo.resp.OrderSearchRespVO
     */
    public OrderSearchRespVO orderSearch(OrderSearchReqVO reqVO) {
        String orderNo = reqVO.getOrderNo();
        if(!BloomFilterUtils.isContains(BloomFilterEnum.TB_ORDER_BLOOM_FILTER.getBloomFilterName(),orderNo)){
            log.info("布隆过滤器不存在#则代表数据库一定不存在,则直接返回空,不进行数据库查询#orderNo={}",reqVO.getOrderNo());
            return null;
        }
        QueryWrapper<TbOrder> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("order_no",reqVO.getOrderNo());
        //查询数据库
        List<TbOrder> tbOrders = tbOrderMapper.selectList(queryWrapper);
        if(CollectionUtil.isEmpty(tbOrders)){
            return null;
        }
        TbOrder tbOrder = tbOrders.get(0);
        //使用MapStruct复制对象返回,不暴漏数据库对象给前端
        OrderSearchRespVO respVO = TbOrderCopyMapper.INSTANCE.createOrderSearchRespVO(tbOrder);
        return respVO;
    }

四、总结

  • 针对此场景、布隆过滤器有着小而实用的特点,可以利用较小的内存挡住大部分的请求,从而降低系统压力和数据库压力
  • 布隆过滤器不仅针对此场景有使用的地方,同时也可以针对缓存穿透也是有很大用处,大大降低数据库的压力
  • 这里仅仅只是记录了布隆过滤器特定场景,目前也是我在工作中用的最多的场景,优化效果显著

五、源代码

redis-bloom-filter: 1、这里介绍了简单的布隆过滤器的用法以及实战场景

感兴趣的朋友可以拉下代码进行项目运行,只需要把redis配置更换即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/426248.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2.模拟问题——4.日期问题

日期问题难度并不大&#xff0c;但是代码量非常大&#xff0c;需要较高的熟练度&#xff0c;因此需要着重练习&#xff0c;主要涉及数组和循环两个方面的知识点&#xff0c;需要熟练的测试代码。 两个经典题型 闰年 闰年满足以下两个条件的任意一个 能够被400整除不能够被1…

一文扫盲:订单管理系统,订单是公司生命线。

hello&#xff0c;我是贝格前端工场&#xff0c;本期给大家分享订单管理系统的知识点&#xff0c;欢迎老铁们点赞、关注&#xff0c;如有需求可以私信我们。 一、什么是订单管理系统 单管理系统是一种用于管理和处理订单的软件系统。它通常用于企业、电子商务平台、零售店等需…

分布式存储Ceph应用

Ceph应用一、创建 CephFS 文件系统 MDS 接口1、服务端操作2、客户端操作 二、创建 Ceph 块存储系统 RBD 接口1、创建存储池2、将存储池转换为 RBD 模式3、初始化存储池4、创建镜像5、镜像管理5.1 查看镜像5.2 修改镜像大小5.3 删除和还原镜像 6、Linux客户端使用7、快照管理 三…

使用综合评标法评标时需要注意什么

综合评标法是一种常见的评标方法&#xff0c;它将投标人的技术方案、商务条件、价格等因素综合起来进行评价&#xff0c;以确定中标人。在使用综合评标法进行评标时&#xff0c;需要注意以下几点&#xff1a; 1. 制定合理的评标标准&#xff1a;在评标前&#xff0c;应制定一套…

如何提取图片中某个位置颜色的RGB值,RGB十进制值与十六进制的转换

打开本地的画图工具&#xff0c;把图片复制或截图粘进去&#xff0c;用颜色提取器点对应的位置就可以提取了。 获取到的 RGB 值为 (66,133,244) 转化后的值为 #4285F4。 【内容拓展一】&#xff1a;RGB 十进制值与十六进制的转换 当我们从 RGB 十进制值转换为十六进制值时&a…

【MySQL·8.0·源码】subquery 子查询处理分析(二)

引文 在【MySQL8.0源码】subquery 子查询处理分析&#xff08;一&#xff09;中&#xff0c;已经介绍了 MySQL 子查询的语法树形式&#xff0c;并简单介绍了非相关 scalar 子查询的一些处理流程&#xff0c;本文将继续介绍更多子查询的处理流程。 本文后续以 “分析&#xff0…

HTML5:七天学会基础动画网页6

CSS3自定义字体 ①&#xff1a;首先需要下载所需字体 ②&#xff1a;把下载字体文件放入 font文件夹里&#xff0c;建议font文件夹与 css 和 image文件夹平级 ③&#xff1a;引入字体&#xff0c;可直接在html文件里用font-face引入字体&#xff0c;分别是字体名字和路径 例…

【OrthoFinder】直系同源基因分析工具

目录 OrthoFinder工具介绍 OrthoFinder的安装方法 OrthoFinder使用方法 参数介绍 输入与输出 OrthoFinder结果解读 Comparative_Genomics_Statistics&#xff1a; Gene_Duplication_Events&#xff1a; Gene_Trees: Orthogroups&#xff1a; Orthogroup_Sequences&am…

【比较mybatis、lazy、sqltoy、lambda、操作数据 】操作批量新增、分页查询【一】

orm框架使用Lambda性能比较 环境&#xff1a; idea jdk17 spring boot 3.0.7 mysql 8.0测试条件常规对象 orm 框架是否支持xml是否支持 Lambda对比版本mybatis☑️☑️3.5.4sqltoy☑️☑️5.2.98lazy✖️☑️1.2.3-JDK17 数据库表(含有唯一性索引s_u) CREATE TABLE sys_u…

AGM CPLD (AGRV2K )的时钟(外部时钟和片上内部振荡器)

AGM CPLD &#xff08;AGRV2K &#xff09;的时钟(外部时钟和片上内部振荡器) 外部晶振 与 内部振荡器&#xff1a; mcu 和 cpld 联合编程时&#xff0c; 整颗芯片需要一颗外部晶振。 &#xff08;芯片有内部振荡器&#xff0c; 但误差较大&#xff0c; 校准后 5%以内误差&…

基于springboot实现企业员工绩效考评系统项目【项目源码+论文说明】

基于springboot实现企业员工绩效考评系统演示 摘要 时代的变化速度实在超出人类的所料&#xff0c;21世纪&#xff0c;计算机已经发展到各行各业&#xff0c;各个地区&#xff0c;它的载体媒介-计算机&#xff0c;大众称之为的电脑&#xff0c;是一种特高速的科学仪器&#xf…

【web | CTF】BUUCTF [HCTF 2018]WarmUp

天命&#xff1a;这题本地php代码是无法复现的 首先打开网站&#xff0c;啥也没有&#xff0c;查看源码 发现文件&#xff0c;打开访问一下看看&#xff0c;发现是代码审计 <?phphighlight_file(__FILE__);class emmm{public static function checkFile(&$page){$whit…

C语言-------指针进阶(2)

1.指针数组 指针数组表较简单&#xff0c;类比整型数组&#xff0c;字符数组&#xff0c;整型数组里面的元素都是整型变量&#xff0c;字符数组里面 的元素是字符类型&#xff0c;那么指针数组就是数组里面的每个元素都是指针类型&#xff0c;例如int*arr[5]就是一个 指针数…

18个惊艳的可视化大屏(第12辑):智慧校园与教育方向

智慧校园可视化大屏通过数据可视化技术&#xff0c;将学校各个方面的数据信息进行展示&#xff0c;可以提高信息公开透明度、优化校园管理、提高学生教育质量和提高校内活动宣传效果等。 1提高信息公开透明度&#xff1a; 通过大屏幕展示校园各个方面的数据信息&#xff0c;可…

Golang Vs Java:为您的下一个项目选择正确的工具

Java 首次出现在 1995 年&#xff0c;由 James Gosling 和 Sun Microsystems 的其他人开发的一种新编程语言。从那时起&#xff0c;Java 已成为世界上最受欢迎和广泛使用的编程语言之一。Java 的主要特点包括其面向对象的设计、健壮性、平台独立性、自动内存管理以及广泛的内置…

【InternLM 实战营笔记】OpenCompass大模型评测

随着人工智能技术的快速发展&#xff0c; 大规模预训练自然语言模型成为了研究热点和关注焦点。OpenAI于2018年提出了第一代GPT模型&#xff0c;开辟了自然语言模型生成式预训练的路线。沿着这条路线&#xff0c;随后又陆续发布了GPT-2和GPT-3模型。与此同时&#xff0c;谷歌也…

击鼓传花游戏

有N个小朋友围成一圈玩击鼓传花游戏&#xff0c;将小朋友编号为1-N&#xff0c;从1号开始传花&#xff0c;每次传3个&#xff0c;拿到花的小朋友表演节目后退出。任给N&#xff0c;问最后一个表演的小朋友编号是多少&#xff1f;例如&#xff1a;输入5&#xff0c;从1号开始传花…

Java网络通信TCP

目录 TCP两个核心类 服务端 1.用ServerSocker类创建对象并且手动指定端口号 2.accept阻塞连接服务端与客户端 3.给客户端提供处理业务方法 4.处理业务 整体代码 客户端 1.创建Socket对象&#xff0c;并连接服务端的ip与端口号 2.获取Socket流对象&#xff0c;写入数据…

基于springboot+vue的智能学习平台系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

2024年阿里云2核4G配置服务器测评_ECS和轻量性能测评

阿里云2核4G服务器多少钱一年&#xff1f;2核4G服务器1个月费用多少&#xff1f;2核4G服务器30元3个月、85元一年&#xff0c;轻量应用服务器2核4G4M带宽165元一年&#xff0c;企业用户2核4G5M带宽199元一年。本文阿里云服务器网整理的2核4G参加活动的主机是ECS经济型e实例和u1…