这是今天在测试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...
从上面的日志也可以看出,如果要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个如下:
参考:
3、kill
原文地址:http://blog.csdn.net/limingjian/article/details/43734811