我正在寻找一种最简单的方法来模仿慢速 Redis 服务器(从我现在正在调试的客户端的角度来看)。
理想情况下,这将是一个DEBUG SLEEP <seconds>
命令,但 AFAIK 没有这样的事情。
比如说,我可以使用BLPOP
阻塞读取——但这需要一个单独的线程来解除阻塞……有没有更简单的方法?
实际上,有一个 debug sleep 命令可以完全满足您的要求。它在 debug.c 文件中定义为:
} else if (!strcasecmp(c->argv[1]->ptr,"sleep") && c->argc == 3) {
double dtime = strtod(c->argv[2]->ptr,NULL);
long long utime = dtime*1000000;
usleep(utime);
addReply(c,shared.ok);
} else {
请注意,它会阻塞整个 Redis 事件循环(所有连接),而 BLPOP 只会阻塞一个连接。
> ./redis-cli debug sleep 2
... 2 seconds wait ...
OK
使用 BLPOP,您不需要第二个线程,因为您可以指定超时:
> ./redis-cli blpop dummy_key_which_does_not_exist 2
... 2 seconds wait ...
(nil)
另一种使 Redis 无响应的方法是发送 STOP 和 CONT 信号。获得实例的 pid 后,只需启动:
kill -STOP $pid
sleep 1
kill -CONT $pid
使用这个信号技巧,redis 实例的所有线程都将被冻结(即不仅是事件循环)。这包括 I/O 后台线程。