停止Redis服务需要注意的事

这是今天在测试Redis3.0.0集群的时候偶然遇到的情况。在停止Redis服务时,我分别用了pkill redis-server和kill -9 redis-pid的方式停止Redis服务,但Redis的日志输出却不一样。

使用pkill停止Redis时,,输入的日志如下。说明Redis是正常退出的。

16017:signal-handler (1423639887) Received SIGTERM scheduling shutdown…16017:M 10 Feb 23:31:27.163 # User requested shutdown…16017:M 10 Feb 23:31:27.164 * Calling fsync() on the AOF file.16017:M 10 Feb 23:31:27.164 * Saving the final RDB snapshot before exiting.16017:M 10 Feb 23:31:27.213 * DB saved on disk16017:M 10 Feb 23:31:27.213 # Redis is now ready to exit, bye bye… 而使用kill -9停止Redis时,Redis没有任何日志输出,说明用kill命令停止Redis服务是不对的。

从上面的日志也可以看出,如果要Redis正常退出,需要给Redis发出一个SIGTERM信号。而pkill是将含有参数的所有进程kill掉,如果要kill单个进程,并且发出SIGTERM命令可不可以呢?答案是可以的,通过kill -15 redis-pid。

现在总结一下,如果要正常停止Redis服务,可以通过pkill命令停止所有Redis服务或者使用kill -15redis-pid停止某一个Redis服务。

下面顺便说一下pkill和kill。

pkill:通过名称和其它属性查找或者发信号给进程。

kill:可以通过kill -l命令查看到kill有64个参数,常用的5个如下:

15) SIGTERM:程序结束(terminate)信号, 与SIGKILL不同的是该信号可以被阻塞和处理。通常用来要求程序自己正常退出,shell命令kill缺省产生这个信号。如果进程终止不了,我们才会尝试SIGKILL。

参考:

1、linux kill信号列表

2、SIGTERM vs. SIGKILL

3、kill

4、kill,killall,pkill 的区别

而是深沉的意志恢弘的想象炙热的恋情;青春是生命的深泉在涌流。

停止Redis服务需要注意的事

相关文章:

你感兴趣的文章:

标签云: