189 8069 5689

SpringBoot项目中Redis之管道技术

环境:springboot2.3.9.RELEASE + redis3.2.100

Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。这意味着通常情况下一个请求会遵循以下步骤:

  • 客户端向服务端发送一个查询请求,并监听Socket返回,通常是以阻塞模式,等待服务端响应。
  • 服务端处理命令,并将结果返回给客户端。

Redis 管道技术

Redis 管道技术可以在服务端未响应时,客户端可以继续向服务端发送请求,并最终一次性读取所有服务端的响应。

Redis普通请求模型与管道请求模型对比

(普通请求模型)来源网络

RTT(Round-Trip Time),就是往返时延,在计算机网络中它是一个重要的性能指标,表示从发送端发送数据开始,到发送端收到来自接收端的确认(接收端收到数据后便立即发送确认),总共经历的时延。

一般认为,单向时延 = 传输时延t1 + 传播时延t2 + 排队时延t3

(管道请求模型)来源网络

性能对比

依赖

 
 
 
 
  1.             org.springframework.boot
  2.             spring-boot-starter-data-redis
  3.         
  4.         
  5.             org.apache.commons
  6.             commons-pool2

配置文件

 
 
 
 
  1. spring:
  2.   redis:
  3.     host: localhost
  4.     port: 6379
  5.     password: ******
  6.     database: 4
  7.     lettuce:
  8.       pool:
  9.         maxActive: 8
  10.         maxIdle: 100
  11.         minIdle: 10
  12.         maxWait: -1

普通方法

 
 
 
 
  1. @Resource
  2. private StringRedisTemplate stringRedisTemplate ;
  3. public void execNormal() {
  4.         long start = System.currentTimeMillis() ;
  5.         for (int i = 0; i < 100_000; i++) {
  6.             stringRedisTemplate.opsForValue().set("k" + i, "v" + i) ;
  7.         }
  8.         System.out.println("耗时:" + (System.currentTimeMillis() - start) + " ms") ;
  9. }

测试结果

总耗时:47秒左右

管道技术

 
 
 
 
  1. public void execPipeline() {
  2.         long start = System.currentTimeMillis() ;
  3.         stringRedisTemplate.executePipelined(new RedisCallback() {
  4.             @Override
  5.             public Object doInRedis(RedisConnection connection) throws DataAccessException {
  6.                 for (int i = 0; i < 100_000; i++) {
  7.                     connection.set(("pk" + i).getBytes(), ("pv" + i).getBytes()) ;
  8.                 }
  9.                 return null ;
  10.             }
  11.         }) ;
  12.         System.out.println("耗时:" + (System.currentTimeMillis() - start) + " ms") ;
  13. }
  14. 测试结果

    耗时:13秒左右

    性能提升了3倍多。

    完毕!!!


    网站标题:SpringBoot项目中Redis之管道技术
    标题来源:http://www.cdxtjz.cn/article/ccdiopj.html

    联系我们

    您好HELLO!
    感谢您来到成都网站建设公司,若您有合作意向,请您为我们留言或使用以下方式联系我们, 我们将尽快给你回复,并为您提供真诚的设计服务,谢谢。
    • 电话:028- 86922220 18980695689
    • 商务合作邮箱:631063699@qq.com
    • 合作QQ: 532337155
    • 成都网站设计地址:成都市青羊区锣锅巷31号五金站写字楼6楼

    小谭建站工作室

    成都小谭网站建设公司拥有多年以上互联网从业经验的团队,始终保持务实的风格,以"帮助客户成功"为已任,专注于提供对客户有价值的服务。 我们已为众企业及上市公司提供专业的网站建设服务。我们不只是一家网站建设的网络公司;我们对营销、技术、管理都有自己独特见解,小谭建站采取“创意+综合+营销”一体化的方式为您提供更专业的服务!

    小谭观点

    相对传统的成都网站建设公司而言,小谭是互联网中的网站品牌策划,我们精于企业品牌与互联网相结合的整体战略服务。
    我们始终认为,网站必须注入企业基因,真正使网站成为企业vi的一部分,让整个网站品牌策划体系变的深入而持久。