在https://serverfault.com/questions/418735/unbelievable-issue-a-single-apache-process-takes-4-gb-of-memory之后,我发布了一个新问题,因为我能够确定它的事实当连接的客户端是 Googlebot 时发生。
“它”是指一个 apache 进程占用 5 GB 的内存?!
有谁知道这可能是什么原因?
非常感谢您的帮助!
我发现另一个问题完全相同但没有答案: https ://serverfault.com/questions/161478/apache-process-consuming-all-memory-on-the-server
我们的环境使用 PHP 和 postgresql :
# httpd -V
Server version: Apache/2.2.3
Server built: Jun 6 2012 10:00:42
Server's Module Magic Number: 20051115:3
Server loaded: APR 1.2.7, APR-Util 1.2.7
Compiled using: APR 1.2.7, APR-Util 1.2.7
Architecture: 64-bit
Server MPM: Prefork
threaded: no
forked: yes (variable process count)
Server compiled with....
-D APACHE_MPM_DIR="server/mpm/prefork"
-D APR_HAS_SENDFILE
-D APR_HAS_MMAP
-D APR_HAVE_IPV6 (IPv4-mapped addresses enabled)
-D APR_USE_SYSVSEM_SERIALIZE
-D APR_USE_PTHREAD_SERIALIZE
-D SINGLE_LISTEN_UNSERIALIZED_ACCEPT
-D APR_HAS_OTHER_CHILD
-D AP_HAVE_RELIABLE_PIPED_LOGS
-D DYNAMIC_MODULE_LIMIT=128
-D HTTPD_ROOT="/etc/httpd"
-D SUEXEC_BIN="/usr/sbin/suexec"
-D DEFAULT_PIDLOG="run/httpd.pid"
-D DEFAULT_SCOREBOARD="logs/apache_runtime_status"
-D DEFAULT_LOCKFILE="logs/accept.lock"
-D DEFAULT_ERRORLOG="logs/error_log"
-D AP_TYPES_CONFIG_FILE="conf/mime.types"
-D SERVER_CONFIG_FILE="conf/httpd.conf"
最后我们找到了解决方案,但不是通过查看日志!
完全不可能通过任何可能的解决方案来了解问题的原因。即使有核心转储或跟踪,也没有理性分析成功!
直到现在,即使解决了问题,我仍然无法理解问题的真正来源和/或如何理解或分析它。因此,很难向您保证我们的解决方案就是真正的解决方案!
据我所知,解决方案似乎是MaxRequestsPerChild: ServerFault post about MaxRequestsPerChild