Redis 管道技术

小柒博客
小柒博客
小柒博客
387
文章
112
评论
2020-05-1311:04:34 评论 18K 1034字阅读3分26秒

Redis 管道技术

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

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

基本的通信过程如下:

[root@localhost ~]# redis-cli

127.0.0.1:6379> incr x

(integer) 1

127.0.0.1:6379> incr x

(integer) 2

127.0.0.1:6379> incr x

(integer) 3

客户端和服务端通过网络进行连接。这样的连接可能非常快(在一个回路网络中),也可能非常慢(在广域网上经过多个结点才能互通的两个主机)。但是无论是否存在网络延迟,数据包从客户端传输到服务端,以及客户端从服务端获得相应都需要花费一些时间。这段时间就成为往返时延(Round Trip Time)。因此当客户端需要执行一串请求的时候,很容易看出它对性能的影响(例如往同一个队列中加入大量元素,或者往数据库中插入大量的键)。如果RTT时长为250毫秒(在基于广域网的低速连接环境下),即使服务器每秒可以处理10万个请求,但是实际上我们依然只能每秒处理最多4个请求。
如果处于一个回路网络中,RTT时长则相当短(我的主机ping 127.0.0.1时只需要0.044ms),但是如果你执行一大串写入请求的时候,还是会有点长。
幸运的是,redis给我们提供了管道技术。

Redis 管道技术

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

实例

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

[root@localhost ~]# $(echo -en "PING\r\n SET test redis\r\nGET test\r\nINCR visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc 172.168.1.3 6379

+PONG

+OK

redis

:1

:2

:3

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

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

管道技术的优势

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

继续阅读
若文章图片、下载链接等信息出错,请在评论区留言反馈,博主将第一时间更新!如果喜欢本站,请打赏支持本站,谢谢!
  • 微信号
  • 微信扫一扫加我!
  • weinxin
  • 微信公众号
  • 微信扫一扫关注我!
  • weinxin
Redis最后更新:2020-6-2
小柒博客
  • 本文由 发表于 2020-05-1311:04:34
  • 除非特殊声明,本站文章均为原创,转载请务必保留本文链接
Docker 安装 Redis Docker

Docker 安装 Redis

Docker 安装 Redis Redis 简介 Redis 是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value的NoSQL数据库,并提供多种语言...
Redis 分区 Redis

Redis 分区

Redis 分区 分区是分割数据到多个Redis实例的处理过程,因此每个实例只保存key的一个子集。 分区的优势 通过利用多台计算机内存的和值,允许我们构造更大的数据库。 通过多核和多台计...
Redis 客户端连接 Redis

Redis 客户端连接

Redis 客户端连接 Redis 通过监听一个TCP端口或者Unix socket的方式来接收来自客户端的连接,当一个连接建立后,Redis内部会进行以下一些操作: 首先,客户端so...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: