3

解决方案是替换这一行:

check process apache with pidfile /var/run/httpd.pid

有了这条线:

check process httpd with pidfile /var/run/httpd/httpd.pid

而且我还删除了“组 apache”。

原帖:

在 CentOS 上安装Monit并为 Apache (httpd) 服务设置警报后,该服务不再创建 /var/run/httpd.pid 文件。

httpd 服务运行正常。

最重要的是,好像这还不够,Monit 将服务的状态报告为:执行失败

自然,重新启动此类服务的唯一方法是杀死它,因为“重新启动”脚本看不到任何正在运行的进程。

这些是 /etc/monit.d/monitrc 文件的内容:

set daemon  10
set logfile syslog facility log_daemon
set mailserver localhost
set mail-format { from: me@server.com }
set alert bugs@server.com
set httpd port 2812 and
#     SSL ENABLE
#     PEMFILE  /var/certs/monit.pem
allow user:password

check process apache with pidfile /var/run/httpd.pid
group apache
start program = "/etc/init.d/httpd start"
stop program  = "/etc/init.d/httpd stop"
if cpu is greater than 180% for 1 cycles then alert
if totalmem > 1200 MB for 2 cycles then restart
if children > 250 then restart

check process sshd with pidfile /var/run/sshd.pid
start program "/etc/init.d/sshd start"
stop program "/etc/init.d/sshd stop"
if failed port 22 protocol ssh for 5 cycles then restart
if 5 restarts within 25 cycles then timeout

“服务 httpd 重启”的输出:

Stopping httpd:                                            [FAILED]
Starting httpd: (98)Address already in use: make_sock: could not bind to address 0.0.0.0:80
no listening sockets available, shutting down
Unable to open logs
                                                       [FAILED]

任何帮助将不胜感激。

4

3 回答 3

5

尝试将停止程序替换为/usr/sbin/httpd -k stop. 它对我有用。

于 2011-08-08T17:22:01.987 回答
0

我认为 monit 正在以“停止”的形式重新启动;start' 并且在开始新进程之前没有等待 'stop' 完成,因此在不适当的时间删除 pid 文件。至少,这是我在修补所有这些后得出的结论。

我找到了对通过在“停止”语句之后进行 monit sleep 来解决此问题的人的引用。

就我个人而言,我发现当 http 服务器关闭时,用 'start' 替换 'restart' 效果很好。

于 2013-02-05T21:13:26.460 回答
0

我遇到了同样的问题,但/usr/sbin/httpd -k stop似乎没有帮助,因为它仍然试图从 pid 文件中查找进程 ID。

我选择了stop program = "/usr/bin/killall httpd"。我认为这不是很优雅(可能会杀死打开的请求),但这是我能找到重新启动 apache 并由 monit 重新创建 pid 文件的唯一方法。

于 2012-03-19T14:06:30.200 回答