iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >SpringBoot中怎么通过整合Redis实现管道
  • 620
分享到

SpringBoot中怎么通过整合Redis实现管道

2023-06-20 14:06:24 620人浏览 独家记忆
摘要

这篇文章给大家介绍SpringBoot中怎么通过整合Redis实现管道,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. Redis 之管道(pipeline)执行一个Redis命令,Redis客户端和Redis服务器

这篇文章给大家介绍SpringBoot中怎么通过整合Redis实现管道,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。


1. Redis 之管道(pipeline)

执行一个Redis命令,Redis客户端和Redis服务器就需要执行以下步骤:

  • 客户端发送命令到服务器

  • 服务器接受命令请求,执行命令,产生相应的结果;

  • 服务器返回结果给客户端;

  • 客户端接受命令的执行结果,并向用户展示。

Redis命令所消耗的大部分时间都用在了发送命令请求和接收命令结果上面,把任意多条Redis命令请求打包在一起,然后一次性地将它们全部发送给服务器,而服务器则会把所有命令请求都处理完毕之后,一次性地将它们的执行结果全部返回给客户端。

注意事项:

Redis服务器并不会限制客户端在管道中包含的命令数量,但是却会为客户端的输入缓冲区设置默认值为1GB的体积上限:当客户端发送的数据量超过这一限制时,Redis服务器将强制关闭该客户端。因此最好不要一下把大量命令或者一些体积非常庞大的命令放到同一个管道中执行。

除此之外,很多客户端本身也带有隐含的缓冲区大小限制,如果你在使用流水线特性的过程中,发现某些流水线命令没有被执行,或者流水线返回的结果不完整,那么很可能就是你的程序触碰到了客户端内置的缓冲区大小限制。

2. springBoot 整合 Redis 管道实例

SpringBoot 整合 redis 的实例

使用单个的 increment 命令,处理 200w个key:

public class RedisPipelineStudy extends BaseTest {    @Autowired    private StringRedisTemplate stringRedisTemplate;    private static final String PREFIX = "test0:";    @Test    public void test() {        StopWatch stopWatch = new StopWatch();        stopWatch.start("test0");        for (int times = 0; times < 2; times++) {            for (int i = 0; i < 1000000; i++) {                stringRedisTemplate.opsForValue().increment(PREFIX + i, 1L);            }        }        stopWatch.stop();        System.out.println(stopWatch.prettyPrint());    }}

耗时如下所示:是 12 位 ,单位ns

SpringBoot中怎么通过整合Redis实现管道

使用管道 incrBy 处理 200w个key,每次打包300条命令发送给服务器,如下所示:

public class RedisPipelineStudy extends BaseTest {    @Autowired    private StringRedisTemplate stringRedisTemplate;    private static final String PREFIX = "test1:";    @Test    public void test() {        StopWatch stopWatch = new StopWatch();        stopWatch.start("test1");        List<Integer> recordList = new ArrayList<>();        for (int times = 0; times < 2; times++) {            for (int i = 0; i < 1000000; i++) {                try {                    recordList.add(i);                    if (recordList.size() > 300) {                        incrByPipeline(recordList);                        recordList = new ArrayList<>();                    }                } catch (Exception e) {                    System.out.println(e);                }            }            if (!CollectionUtils.isEmpty(recordList)) {                incrByPipeline(recordList);                recordList = new ArrayList<>();            }        }        stopWatch.stop();        System.out.println(stopWatch.prettyPrint());    }    private void incrByPipeline(List<Integer> recordList) {        stringRedisTemplate.executePipelined(new RedisCallback<Object>() {            @Override            public Object doInRedis(RedisConnection connection) throws DataAccessException {                try {                    for (Integer record : recordList) {                        byte[] key = (PREFIX + record).getBytes();                        connection.incrBy(key, 1);                    }                } catch (Exception e) {                    System.out.println(e);                }                return null;            }        });    }}

耗用时间: 11 位 ,单位 :ns,是单个命令耗时的 1/6。

SpringBoot中怎么通过整合Redis实现管道

关于SpringBoot中怎么通过整合Redis实现管道就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: SpringBoot中怎么通过整合Redis实现管道

本文链接: https://www.lsjlt.com/news/297313.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SpringBoot中怎么通过整合Redis实现管道
    这篇文章给大家介绍SpringBoot中怎么通过整合Redis实现管道,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. Redis 之管道(pipeline)执行一个Redis命令,Redis客户端和Redis服务器...
    99+
    2023-06-20
  • SpringBoot整合Redis管道的示例代码
    目录1. Redis 之管道(pipeline)2. SpringBoot 整合 Redis 管道实例1. Redis 之管道(pipeline) 执行一个Redis命令,Redis...
    99+
    2024-04-02
  • SpringBoot中怎么整合Redis
    SpringBoot中怎么整合Redis,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、安装首先要在本地安装一个redis程序,安装过程十分简单(略过),安装完成后进入到...
    99+
    2023-06-16
  • SpringBoot中通过AOP整合日志文件的实现
    目录1.导入相关的依赖 2.log4j2 日志文件 3.dao层的接口以及实现类 4.Service层业务实现类 5.Controller层接口控制类 6.编写业务类增强类,加入一个...
    99+
    2024-04-02
  • SpringBoot怎么整合Spring Cache实现Redis缓存
    今天小编给大家分享一下SpringBoot怎么整合Spring Cache实现Redis缓存的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下...
    99+
    2023-07-02
  • springboot中如何通过整合Mapper实现单表操作
    本文小编为大家详细介绍“springboot中如何通过整合Mapper实现单表操作”,内容详细,步骤清晰,细节处理妥当,希望这篇“springboot中如何通过整合Mapper实现单表操作”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-06-08
  • SpringBoot整合Redis的实现示例
    目录1.需求说明2.整合实现2.1.创建Springboot工程2.2.redis配置3.编写测试类4.注意事项和细节1.需求说明 在 springboot 中 , 整合 redis...
    99+
    2023-01-28
    SpringBoot整合Redis SpringBoot Redis整合
  • SpringBoot怎么整合Redis实现热点数据缓存
    本篇内容主要讲解“SpringBoot怎么整合Redis实现热点数据缓存”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SpringBoot怎么整合Redis实现热点数据缓存”吧!我们以IDEA ...
    99+
    2023-07-05
  • Linux中怎么实现管道通信
    Linux中怎么实现管道通信,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、定义管道是单向的、先进先出的。它将一个程序的输入和另一个程序的输出连接起来。数据被...
    99+
    2023-06-13
  • SpringBoot怎么整合Redis将对象写入redis中
    本篇内容主要讲解“SpringBoot怎么整合Redis将对象写入redis中”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SpringBoot怎么整合Redis将对象写入redis中”吧!1、...
    99+
    2023-06-30
  • SpringBoot整合Redis将对象写入redis的实现
    目录1、环境搭建 2、代码编写3、测试1、环境搭建 创建一个SpringBoot项目,普通的web项目就可以了,我这里使用的是start.aliyun 引入依赖: (1)...
    99+
    2024-04-02
  • SpringBoot怎么整合Redis实现高并发数据缓存
    这篇文章主要讲解了“SpringBoot怎么整合Redis实现高并发数据缓存”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot怎么整合Redis实现高并发数据缓存”吧!什么是...
    99+
    2023-07-05
  • Springboot详解整合SpringSecurity实现全过程
    目录使用Basic认证模式使用form表形式登录实现权限控制自定义登录页面结合数据库实现RBAC权限模型权限控制java代码动态绑定数据库所有权限使用Basic认证模式 1、mave...
    99+
    2024-04-02
  • Springboot 中怎么整合logback日志管理
    Springboot 中怎么整合logback日志管理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.spring-boot-starter\spring-boot-star...
    99+
    2023-06-19
  • SpringBoot怎么整合Redis实现序列化存储Java对象
    今天小编给大家分享一下SpringBoot怎么整合Redis实现序列化存储Java对象的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2023-07-05
  • SpringBoot整合Redis之怎么编写RedisConfig
    这篇文章主要介绍了SpringBoot整合Redis之怎么编写RedisConfig的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringBoot整合Redis之怎么编写RedisConfig文章都会有所收...
    99+
    2023-07-02
  • SpringBoot整合websocket实现即时通信聊天
    目录一、技术介绍1.1 客户端WebSocket1.1.1 函数1.1.2 事件1.2 服务端WebSocket二、实战 2.1、服务端2.1.1引入maven依赖2.1....
    99+
    2024-04-02
  • springboot怎么通过spel结合aop实现动态传参
    这篇文章主要介绍了springboot怎么通过spel结合aop实现动态传参的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇springboot怎么通过spel结合aop实现动态传参文章都会有所收获,下面我们一起...
    99+
    2023-07-06
  • spring boot怎么整合quartz实现通过页面操作管理定时任务
    这篇文章主要介绍“spring boot怎么整合quartz实现通过页面操作管理定时任务”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“spring boot怎么整合...
    99+
    2024-04-02
  • SpringBoot整合Mybatis-plus和Redis实现投票功能
    目录一、背景介绍二、开发环境三、技术实现1. 配置Redis2. 配置MyBATis-plus3. 实现投票功能四、测试运行五、总结一、背景介绍 投票功能是一个非常常见的Web应用场景,SpringBoot作为当今流行的...
    99+
    2023-06-01
    SpringBoot Redis实现投票功能 SpringBoot Redis投票 Redis投票
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作