php redis pipeline管道技术

概念

如果需要一次执行多个redis命令,以往的方式需要发送多次命令请求,有redis服务器依次执行,并返回结果,为了解决此类问题,设计者设计出了redis管道命令:客户端可以向服务器发送多个请求,而不必等待回复,并最终在一个步骤中读取回复,从而大大增加了协议性能

代码示例
1 、不使用管道技术

$stime=microtime(true); //获取程序开始执行的时间
echo '开始内存:'.memory_get_usage(), ''; echo PHP_EOL;
$redis = new \Redis();

$redis->connect('127.0.0.1',6379);



$t1 = time();
for($i= 0; $i<10000 ; $i++) {

    $redis->set("key::$i",str_pad($i,4,'0',0));

    $redis->get("key::$i");

}


$etime=microtime(true);//获取程序执行结束的时间

$total=($etime-$stime);   //计算差值


echo "[页面执行时间:{$total} ]s"; echo PHP_EOL;
echo '运行后内存:'.memory_get_usage(), ''; echo PHP_EOL;
[root@localhost PHPCreeper-Application]# php test.php
开始内存:389984
[页面执行时间:1.1715140342712 s
运行后内存:398912

2 、使用管道技术

<?php
$stime=microtime(true); //获取程序开始执行的时间
echo '开始内存:'.memory_get_usage(), ''; echo PHP_EOL;
$redis = new \Redis();

$redis->connect('127.0.0.1',6379);


$pipe=$redis->multi($redis::PIPELINE);

for($i= 0; $i<10000 ; $i++) {

    $pipe->set("key::$i",str_pad($i,4,'0',0));

    $pipe->get("key::$i");

}

$replies=$pipe->exec();

$etime=microtime(true);//获取程序执行结束的时间

$total=($etime-$stime);   //计算差值


echo "[页面执行时间:{$total} ]s"; echo PHP_EOL;
echo '运行后内存:'.memory_get_usage(), ''; echo PHP_EOL;

[root@localhost PHPCreeper-Application]# php test.php
开始内存:390024
[页面执行时间:0.017589092254639 ]s
运行后内存:1771680

参数说明:
Redis::MULTI或Redis::PIPELINE. 默认是 Redis::MULTI
Redis::MULTI:将多个操作当成一个事务执行
Redis::PIPELINE:让(多条)执行命令简单的,更加快速的发送给服务器,但是没有任何原子性的保证

不使用管道

开始内存:389984
[页面执行时间:1.1715140342712 s
运行后内存:398912

使用管道
开始内存:390024
[页面执行时间:0.017589092254639 ]s
运行后内存:1771680

可以看到使用管道提高了将近100倍。但是缺点也很明显内存飙升的很厉害。没有任何原子性的保证。批量执行命令,不能无限。

猜你喜欢

转载自blog.csdn.net/weixin_36851500/article/details/106213257