欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

一次Redis的使用Bug记要(exec)

程序员文章站 2022-04-23 16:48:02
...
一次Redis的使用Bug记录(exec)

博主在一次项目中,使用了工具类中的Redis类,因为该Redis没有封装管道pipeline和exec命令,所以就大笔一挥来了一段__call;

代码如下(其中$this->_connect()返回的为一个Redis实例)。

一次Redis的使用Bug记要(exec)

之后的事情感觉中文已经无法表述,上代码就是类似这样的

$redis->pipeline();

$redis->lpop($key);

$redis->lpop($key);

$redis->exec();

自己写了简单例子测试之后,正常情况下应该会返回$key队列中的两个栈顶元素,即array('item1','item2');但是该次最终的返回结果竟然是NULL,博主这时候

就超级疑惑,难道是call_user_fun_array()这个申请的函数是木有返回值,尼玛,那这样不是坑死老爹吗。而这仅仅是个人猜测,php宝册在手不虚,发现并无此

说明,但是有一个简单的例子为,看下面的例子加亲自测试是有返回值,那就是说此次猜想不成功。

一次Redis的使用Bug记要(exec)

好吧,只能继续debug了,许久之后依然木有发现问题,请教公司一同事,他来了之后发现你说那就既然是$this->_connect()是一个redis对象,

那上面不是还有一个$this->_redis的句柄吗,直接替换,之后在神奇的事情发生了,尼玛有返回值了。

一次Redis的使用Bug记要(exec)

好吧,那问题就可以猜想一二了,这个肯定说明了$this->_connect()和$this->_redis肯定有哪些地方不太一样,如上面的代码,我们直接把两个变量dump了出来。

之后发现是这样的,如下图看官们应该明白这根本是不同的两个资源。

一次Redis的使用Bug记要(exec)

感觉知道问题所在了,返回了看_connect()函数,发现里面是没有Redis单例的,每次都是new了一个Redis对象。

所以还不知道问题所在的看官可以继续跟着哥往下走。

一次Redis的使用Bug记要(exec)

这个问题呢,我们技术人啥也不说了,上代码,在一批redis的操作命令中,动用了三个不同的redis对象,第三次是直接exec,连pipeline都木有,那肯定是NULL.

这你敢相信,反正我是信了,我也是醉了,当然也是我自己坑了自己。问题到此真相大白。有一次自坑的打怪之路。

一次Redis的使用Bug记要(exec)

一次Redis的使用Bug记要(exec)

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频