gpt4 book ai didi

SpringBoot整合Redis管道的示例代码

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 37 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章SpringBoot整合Redis管道的示例代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

1. Redis 之管道(pipeline)

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

  • 客户端发送命令到服务器;
  • 服务器接受命令请求,执行命令,产生相应的结果;
  • 服务器返回结果给客户端;
  • 客户端接受命令的执行结果,并向用户展示。

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

注意事项:

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

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

2. SpringBoot 整合 Redis 管道实例

SpringBoot 整合 redis 的实例 。

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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条命令发送给服务器,如下所示:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
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管道的示例代码的文章就介绍到这了,更多相关SpringBoot整合Redis管道内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://blog.csdn.net/qq_38737992/article/details/118469059 。

最后此篇关于SpringBoot整合Redis管道的示例代码的文章就讲到这里了,如果你想了解更多关于SpringBoot整合Redis管道的示例代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

37 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com