博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Redis新特性——pipeline(管道)
阅读量:7030 次
发布时间:2019-06-28

本文共 2100 字,大约阅读时间需要 7 分钟。

hot3.png

redis是一个cs模式的tcp server,使用和http类似的请求响应协议。一个client可以通过一个socket连接发起多个请求命令。每个请求命令发出后client通常会阻塞并等待redis服务处理redis处理完后请求命令后会将结果通过响应报文返回给client。基本的通信过程如下:

Client: INCR X

Server: 1
Client: INCR X
Server: 2
Client: INCR X
Server: 3
Client: INCR X
Server: 4

基本上四个命令需要8tcp报文才能完成。由于通信会有网络延迟,假如从clientserver之间的包传输时间需要0.125秒。那么上面的四个命令8个报文至少会需要1秒才能完成。这样即使redis每秒能处理100个命令,而我们的client也只能一秒钟发出四个命令。这显示没有充分利用 redis的处理能力。除了可以利用mget,mset 之类的单条命令处理多个key的命令外我们还可以利用pipeline的方式从client打包多条命令一起发出,不需要等待单条命令的响应返回,而redis服务端会处理完多条命令后会将多条命令的处理结果打包到一起返回给客户端。通信过程如下:

Client: INCR X

Client: INCR X
Client: INCR X
Client: INCR X
Server: 1
Server: 2
Server: 3
Server: 4

假设不会因为tcp报文过长而被拆分。可能两个tcp报文就能完成四条命令,client可以将四个incr命令放到一个tcp报文一起发送,server则可以将四条命令的处理结果放到一个tcp报文返回。通过pipeline方式当有大批量的操作时候。我们可以节省很多原来浪费在网络延迟的时间。需要注意到是用 pipeline方式打包命令发送,redis必须在处理完所有命令前先缓存起所有命令的处理结果。打包的命令越多,缓存消耗内存也越多。所以并是不是打包的命令越多越好。具体多少合适需要根据具体情况测试。下面是个jedis客户端使用pipeline的测试:

package org.security.ibatis.redis;import org.apache.log4j.Logger;import redis.clients.jedis.Jedis;import redis.clients.jedis.Pipeline;/** * author:zyh * since:2013-12-16 * 功能:redis-Pipeline(管道)测试 * 环境:本机xp  局域网linux上的Redis Server */public class RedisPipelineTest {		private static final Logger logger = Logger.getLogger(RedisPipelineTest.class);	private static final int count = 10000;	public static void main(String[] args) {		long startTimes = System.currentTimeMillis();		withoutPipeline(count);		long endTimes = System.currentTimeMillis();		System.out.println("withoutPipeline:" + (endTimes - startTimes) + "毫秒");				startTimes = System.currentTimeMillis();		usePipeline(count);		endTimes = System.currentTimeMillis();		System.out.println("usePipeline:" + (endTimes - startTimes) + "毫秒");	}		/**	 * 不使用Pipeline发送命令	 * @param count	 */	private static void withoutPipeline(int count) {		Jedis jedis = null;		try {			jedis = new Jedis("192.168.6.205", 6379);			for(int i=0; i
output:
withoutPipeline:4953毫秒
usePipeline:31毫秒
可以看到
测试结果还是很明显有较大的差距,所以多次操作用
pipeline
还是有明显的优势。我用的是
Xp
中的
Jedis Java
客户端程序连接局域网的
Linux
物理机上的
Redis Server

转载于:https://my.oschina.net/xiaomaoandhong/blog/184660

你可能感兴趣的文章
LNMP下动静分离部署phpmyadmin软件包
查看>>
如何写更好的自动化测试用例
查看>>
60再谈指针
查看>>
repost
查看>>
android异步加载AsyncTask
查看>>
GCC Stack-Smashing Protector
查看>>
虚拟机Visualbox安装Ubuntu Server
查看>>
用带余除法可以解决一切部分分式的题目
查看>>
vs 生成事件
查看>>
jmeter 实战项目总结2——微信端
查看>>
php.ini 中文版
查看>>
即时通信客户端流程,
查看>>
布隆过滤器redis缓存
查看>>
01-数据仓库之数据建模
查看>>
Nginx 安装
查看>>
hidesBottomBarWhenPushed 设置为NO的问题
查看>>
cisco常用命令详解
查看>>
谁在追踪谁?
查看>>
HTTP请求返回状态码详解
查看>>
句柄类
查看>>