在redis中优化频繁操作redis产生多次链接引发的网络延时

在程序中可能存在频繁操作redis,每次操作redis都需要产生网络链接,虽然每次操作的返回处理非常快(几十甚至几毫米),但是非常多的redis操作在超高的并发请求中,还是有必要优化的,那么php中如何避免产生多次操作,每次都链接一次redis呢?其实和上篇文章的方法是一样,仅仅是把 multi 的参数指定为Redis::PIPELINE,但是这样操作禁止了原子性操作,代码如下:

<?php
$redis = new \Redis(); 
$redis->connect('127.0.0.1', 6379);
$key = 'watchkey';

$redis->watch($key);
//仅仅这里的参数不同
$redis->multi(Redis::PIPELINE);

sleep(3);
$redis->incr($key);
$redis->get($key);

$r = $redis->exec();
var_dump($r);

function getRedis(){
   $redis = new \Redis(); 
   $redis->connect('127.0.0.1', 6379); 
   return $redis;
}

和上次一样,连着执行3次看看结果:
redis访问优化
发现 watchkey 被执行了3次,watch 并没有起到作用。
这样的操作仅仅确保进程之间不会产生数据冲突,才能使用这个方法。

此条目发表在redis分类目录,贴了, 标签。将固定链接加入收藏夹。

发表评论

电子邮件地址不会被公开。 必填项已用*标注

看不清?