守护进程运行了几个小时,然后死机

守护进程运行了几个小时,然后死机

重启服务器后,运行如下:

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
19653 lighttpd 16 0 67584 39m 16m R 21.3 15.3 0:17.60 php-cgi
8006 mysql 15 0 137m 22m 4800 S 5.3 8.8 1:07.91 mysqld
13364 lighttpd 16 0 63560 39m 20m S 2.3 15.3 0:34.57 php-cgi
1 root 15 0 2068 648 556 S 0.0 0.2 0:00.55 init
1741 root 15 0 2196 1012 816 R 0.0 0.4 0:00.01 top
7449 root 15 -4 2152 552 344 S 0.0 0.2 0:00.00 udevd
7839 root 15 0 1724 608 512 S 0.0 0.2 0:00.00 syslogd
7888 root 18 0 7024 1056 660 S 0.0 0.4 0:00.00 sshd
7899 root 18 0 2724 872 700 S 0.0 0.3 0:00.00 xinetd
7934 root 18 0 3616 1288 1116 S 0.0 0.5 0:00.00 mysqld_safe
11499 root 18 0 9180 1676 660 S 0.0 0.6 0:00.03 sendmail
13330 smmsp 20 0 8132 1472 608 S 0.0 0.6 0:00.00 sendmail
13344 lighttpd 15 0 6792 2732 756 S 0.0 1.0 0:01.30 lighttpd
13347 lighttpd 21 0 47144 8984 6168 S 0.0 3.4 0:00.09 php-cgi
13356 lighttpd 15 0 47144 8984 6168 S 0.0 3.4 0:00.09 php-cgi
13358 lighttpd 15 0 68128 43m 20m S 0.0 17.0 0:08.42 php-cgi
13360 lighttpd 21 0 47144 8988 6168 S 0.0 3.4 0:00.08 php-cgi
13365 lighttpd 15 0 47144 8992 6168 S 0.0 3.4 0:00.09 php-cgi
13446 root 18 0 4408 1108 560 S 0.0 0.4 0:00.00 crond
13669 xfs 18 0 3456 1180 728 S 0.0 0.5 0:00.00 xfs
13681 root 18 0 5580 708 428 S 0.0 0.3 0:00.00 saslauthd
13682 root 18 0 5580 444 164 S 0.0 0.2 0:00.00 saslauthd
13767 root 15 0 7496 5432 1604 S 0.0 2.1 0:00.03 miniserv.pl
21715 lighttpd 16 0 78908 49m 15m S 0.0 19.2 0:16.40 php-cgi
32674 root 18 0 10016 2828 2284 S 0.0 1.1 0:00.03 sshd
32747 root 15 0 3752 1536 1236 S 0.0 0.6 0:00.02 bash

但几个小时后,就会变成这样:

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 root 15 0 2068 656 556 S 0.0 0.3 0:03.89 init
3723 root 15 0 4408 1112 564 S 0.0 0.4 0:00.16 crond
9220 root 18 0 9860 2828 2288 S 0.0 1.1 0:00.08 sshd
9688 root 15 0 3752 1540 1236 S 0.0 0.6 0:00.11 bash
10210 root 15 0 2196 1004 816 R 0.0 0.4 0:00.00 top
21529 root 15 0 1724 608 512 S 0.0 0.2 0:03.19 syslogd
21602 root 18 0 7024 1052 660 S 0.0 0.4 0:13.52 sshd
21623 root 18 0 2724 868 700 S 0.0 0.3 0:00.00 xinetd
21717 mysql 15 0 138m 24m 4988 S 0.0 9.4 79:19.17 mysqld

这种情况会反复发生。webmin 也会死机



我在用着:

—CentOS 5.3

-lighttpd
"max-procs" => 1
"PHP_FCGI_CHILDREN" => "6"
"PHP_FCGI_MAX_REQUESTS" => "500"

-PHP
使用 eaccelerator

-monit
respawn 中的 monit 错误:Id "mo" respawning too fast: disabled for 5 minutes
inittab 中的 monit 代码:mo:234:respawn:/usr/bin/monit -Ic /etc/monit.d/monitrc

我也不知道如何修复 inittab 中的 monit 错误

在此之前,当服务器使用以下配置运行时,不会发生类似的事情:
-default mod_fastcgi config
-without monit

因此,我开始使用 monit,因为 lighttpd 在我睡觉时死机,而且我的网站有点慢,再加上 php-cgi 的 RAM 使用率很高(我的 RAM 只有 256MB,在其中托管了 20 多个网站)

答案1

您可能正在与内存不足杀手发生冲突。

增加服务器的 RAM 数量,如果不可能,则增加交换空间。

我有点惊讶你能让 CentOS 5.3 在如此少的内存下做任何有用的事情。

答案2

将其减少FCGI_CHILDREN为零。建议在较新的 lighttpd 版本中使用。请设置更多max-procs。尝试调整 max-procs 的数量。如果您的网站不是一直处于繁忙状态,那么 2 个就足够了。

相关内容