美文网首页JavaJava高开发Java 杂谈
详解Redis高级特效之管道技术

详解Redis高级特效之管道技术

作者: java高并发 | 来源:发表于2019-06-05 14:08 被阅读4次

概述

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

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

Redis 管道技术

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

查看 redis 管道,只需要启动 redis 实例并输入以下命令:

<pre style="-webkit-tap-highlight-color: transparent; box-sizing: border-box; font-family: Consolas, Menlo, Courier, monospace; font-size: 16px; white-space: pre-wrap; position: relative; line-height: 1.5; color: rgb(153, 153, 153); margin: 1em 0px; padding: 12px 10px; background: rgb(244, 245, 246); border: 1px solid rgb(232, 232, 232); font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration-style: initial; text-decoration-color: initial;">$(echo -en "PING
SET w3ckey redis
GET w3ckey
INCR visitor
INCR visitor
INCR visitor
"; sleep 10) | nc localhost 6379
</pre>

详解Redis高级特效之管道技术

以上实例中我们通过使用 PING 命令查看redis服务是否可用, 之后我们们设置了 w3ckey 的值为 redis,然后我们获取 w3ckey 的值并使得 visitor 自增 3 次。

在返回的结果中我们可以看到这些命令一次性向 redis 服务提交,并最终一次性读取所有服务端的响应。


管道技术的优势

管道技术最显著的优势是提高了 redis 服务的性能。

在下面的测试中,使用Redis的Ruby客户端,支持管道技术特性,测试管道技术对速度的提升效果。

详解Redis高级特效之管道技术

从执行上面这个脚本的数据表明,开启了管道操作后,往返时延已经被改善得相当低了。

详解Redis高级特效之管道技术

开启管道后,速度效率提升了5倍。


Redis的管道(Pipelining)操作是一种异步的访问模式,一次发送多个指令,不同步等待其返回结果。这样可以取得非常好的执行效率。有数据表明,某个后台应用,逐个处理大约100万条记录需要几十分钟,经过pileline压缩请求数量后,最后时间缩小到20秒左右。所以正确使用pipeline对性能的提升十分明显。

相关文章

  • 详解Redis高级特效之管道技术

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

  • 高级篇之一

    Redis高级功能之分管道技术、消息队列 一、管道技术 我们先来试试管道技术,Redis 管道技术可以在服务端未响...

  • Redis管道技术的使用

    目录 Redis 管道技术 SpringDataRedis 使用管道 Redis 管道的性能测试 使用管道技术的注...

  • redis 管道技术

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

  • Redis 管道技术

    Redis 管道技术 Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。这意味着通常情况下一个...

  • Redis 管道技术

    Redis 管道技术作为了解,暂时没有实际使用 Redis正常请求情况 Redis是一种基于客户端-服务端模型以及...

  • Redis 管道技术

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

  • Redis 管道技术

    Redis 管道技术 Redis是一种基于客户端-服务端模型(C/S模型)以及请求/响应协议的TCP服务。 这意味...

  • Android开源库项目及库汇总——动画

    动画 Android应用开发之所有动画使用详解– Android应用开发之所有动画使用详解。 动画特效大全– An...

  • Redis学习篇(十二)之管道技术

    通过管道技术降低往返时延当后一条命令不依赖于前一条命令的返回结果时,可以使用管道技术将多条命令一起发送给redis...

网友评论

    本文标题:详解Redis高级特效之管道技术

    本文链接:https://www.haomeiwen.com/subject/xiojxctx.html