我需要在命令行停止 crond。(我正在编写一个脚本,需要停止它,做一些工作,然后重新启动它。我不想删除和替换 crontab 文件,因为它更容易出错。)
但是,当我运行service crond stop
或时sudo /etc/init.d/crond stop
,它会停止,但不到一分钟后又重新启动。
[root@prod-sphinx1 ~]# service crond stop;date
Stopping crond: [ OK ]
Wed Oct 15 05:48:50 UTC 2014
[root@prod-sphinx1 ~]# ps uefxxx | grep crond
root 11891 0.0 0.0 61192 788 pts/0 S+ 05:49 0:00 \_ grep crond HOSTNAME=sphinx01.us-east-1.zoomingo.com TERM=xterm-256color SHELL=/bin/bash HISTSIZE=1000 SSH_CLIENT=50.46.219.220 51260 22 SSH_TTY=/dev/pts/0 USER=root LS_COLORS= EC2_HOME=/home/ec2 MAIL=/var/spool/mail/root PATH=/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/home/ec2/bin:/home/ec2/bin:/root/bin INPUTRC=/etc/inputrc PWD=/root JAVA_HOME=/usr/java/default LANG=en_US.UTF-8 PS1=[\u@prod-sphinx1 \W]\$ SSH_ASKPASS=/usr/libexec/openssh/gnome-ssh-askpass SHLVL=1 HOME=/root LOGNAME=root CVS_RSH=ssh SSH_CONNECTION=50.46.219.220 51260 10.146.200.111 22 PKG_CONFIG_PATH=/usr/lib/pkgconfig:/usr/local/lib/pkgconfig LESSOPEN=|/usr/bin/lesspipe.sh %s G_BROKEN_FILENAMES=1 _=/bin/grep
root 11875 0.0 0.0 17832 1044 ? Ss 05:49 0:00 crond MONIT_DATE=Wed, 15 Oct 2014 05:49:21 +0000 MONIT_HOST=sphinx01.us-east-1.zoomingo.com PATH=/sbin:/usr/sbin:/bin:/usr/bin PWD=/ MONIT_PROCESS_PID=0 MONIT_EVENT=Started MONIT_PROCESS_MEMORY=0 SHLVL=2 MONIT_PROCESS_CPU_PERCENT=0 MONIT_SERVICE=crond MONIT_PROCESS_CHILDREN=0 MONIT_DESCRIPTION=Started _=/usr/sbin/crond
ps -l 说父进程 ID 是 init(这并不奇怪):
[root@prod-sphinx1 ~]# ps -l -p11875
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD
1 S 0 11875 1 0 78 0 - 4458 - ? 00:00:00 crond
pstree 说:
[root@prod-sphinx1 ~]# pstree -p 11875
crond(11875)───crond(11905)───sh(11907)───index-minutely.(11908)───indexer(11910)
它为我提供了正在运行的进程,但没有提供启动它的进程。
不幸的是,pstree 是我 Google 能找到的最好的东西。我该怎么做才能弄清楚这个东西是如何启动的?
编辑:该盒子运行的是CentOS 5.6:
[root@prod-sphinx1 ~]# cat /etc/issue
CentOS release 5.6 (Final)
Kernel \r on an \m
答案1
看起来monit
正在监视你crond
,如果找不到它,它会重新启动它。你应该能够使用 来停止 crond monit stop crond
。