Redis 管道技术

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服务的性能。

原创文章,作者:admin,如若转载,请注明出处:https://hostingchat.cn/301.html

(0)
admin的头像admin
上一篇 2020年5月13日
下一篇 2020年5月13日

相关推荐

  • Linux部署Redis数据库主从架构

    一、Redis主从概述 为了提升redis高可用性,我们除了备份redis dump数据之外,还需要创建Redis主从架构,可以利用从将数据库持久化(数据持久化通俗讲就是把数据保存…

    2017年12月14日
    000
  • Redis 列表(List)

    Redis 列表(List) Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边) 一个列表最多可以包含2^32 &#8211…

    2020年5月12日
    000
  • Redis 事务

    Redis 事务 Redis 事务可以一次执行多个命令,并且带有以下三个重要的保证: 批量操作在发送EXEC命令前被放入队列缓存。 收到EXEC命令后进入事务执行,事务中任意命令执…

    2020年5月13日
    000
  • Linux部署Redis-Sentinel集群

    一、Redis-Sentinel简介 Sentinel(哨岗、哨兵)是Redis的高可用性(high availability)解决方案:由一个或多个Sentinel实例(inst…

    2022年11月28日
    000
  • Redis 性能测试

    Redis简介 REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。 Redis是一个开…

    2020年5月13日
    000
  • Redis 字符串(String)

    Redis 字符串(String) Redis 字符串数据类型的相关命令用于管理redis字符串值,基本语法如下: 语法 127.0.0.1:6379> COMMAND KE…

    2020年5月12日
    000
  • Redis 集合(Set)

    Redis 集合(Set) Redis 的Set是String类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。 Redis 中集合是通过哈希表实现的,所以添加…

    2020年5月12日
    000
  • Redis 键(key)

    Redis 键(key) Redis 键命令用于管理 redis 的键。 语法 Redis 键命令的基本语法如下: 127.0.0.1:6379> COMMAND KEY_N…

    2020年5月12日
    000
  • Redis HyperLogLog

    Redis HyperLogLog Redis 在2.8.9版本添加了HyperLogLog结构。 Redis HyperLogLog是用来做基数统计的算法,HyperLogLog…

    2020年5月12日
    000
  • Redis 配置文件

    Redis 配置 Redis 的配置文件位于Redis安装目录下,文件名为redis.conf(Windows 名为 redis.windows.conf)。 你可以通过CONFI…

    2020年5月12日
    100

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注