redis sigterm 信号

时间:2015-07-31 13:15:34   收藏:0   阅读:1153

        这是今天在测试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 disk
16017: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 -15 redis-pid停止某一个Redis服务。


下面顺便说一下pkill和kill。

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

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


原文:http://my.oschina.net/ruibo/blog/486022

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!