首先,版本:
Apache 2.2.22
PHP 5.3.10
Ubuntu 12.04 LTS(一切都更新)
APC 3.1.7(通过APT而不是PEAR安装)
我遇到的问题是,当发出正常重启(sudo service apache2 graceful
)时,PHP会发生致命错误,导致Apache出现故障。这就是我在/var/log/apache2/error.log
中看到的:
[Tue Apr 30 11:05:33 2013] [notice] Graceful restart requested, doing restart
PHP Fatal error: PHP Startup: apc_mmap: mmap failed: in Unknown on line 0
[Tue Apr 30 11:05:34 2013] [notice] seg fault or similar nasty error detected in the parent process
/etc/php5/conf.d/apc.ini
仅包含以下内容:
extension=apc.so
apc.shm_size=256M
Linode是我的主持人。我有1GB版本和256MB交换分区,因此256M应该是apc.shm_size
的合理值(在最近Linode memory upgrade之前,我只有512MB内存,apc.shm_size
已设置至128M)。
以下是apc.php
:
APC Version 3.1.7
PHP Version 5.3.10-1ubuntu3.6
APC Host [removed]
Server Software Apache/2.2.22 (Ubuntu)
Shared Memory 1 Segment(s) with 256.0 MBytes
(mmap memory, pthread mutex Locks locking)
Start Time 2013/04/30 11:09:44
Uptime 21 minutes
File Upload Support 1
以下是apc.php
中显示的运行时设置:
apc.cache_by_default 1
apc.canonicalize 1
apc.coredump_unmap 0
apc.enable_cli 0
apc.enabled 1
apc.file_md5 0
apc.file_update_protection 2
apc.filters
apc.gc_ttl 3600
apc.include_once_override 0
apc.lazy_classes 0
apc.lazy_functions 0
apc.max_file_size 1M
apc.mmap_file_mask
apc.num_files_hint 1000
apc.preload_path
apc.report_autofilter 0
apc.rfc1867 0
apc.rfc1867_freq 0
apc.rfc1867_name APC_UPLOAD_PROGRESS
apc.rfc1867_prefix upload_
apc.rfc1867_ttl 3600
apc.serializer default
apc.shm_segments 1
apc.shm_size 256M
apc.slam_defense 1
apc.stat 1
apc.stat_ctime 0
apc.ttl 0
apc.use_request_time 1
apc.user_entries_hint 4096
apc.user_ttl 0
apc.write_lock 1
我已经做了大量的搜索,但我无法弄清楚是什么导致了这一点。这可能是PHP或APC或Apache的错误吗?我需要添加/更改一些配置值吗?
感谢您的帮助!
[编辑]
我刚刚尝试更新APC(在apt中删除它并通过PECL安装),但这并没有解决问题。我仍然看到APC 3.1.13的段错误。
答案 0 :(得分:2)
它可能与操作系统中一个段允许的共享内存有关,可以显着低于256MB。
检查sudo sysctl kernel.shmmax
的输出。在我的debian机器上它是33554432(32MB)。
作为一种可能的解决方案。尝试在APC配置中将apc.shm_segments
增加到256/32 = 8。您还可以将段系统允许的共享内存更改为256MB。
sudo sysctl -w kernel.shmmax 268435456
答案 1 :(得分:1)
环顾四周后,我注意到/var/log/syslog
中有一条麻烦的线:
kernel: apache2[11303]: segfault at ffffffff ip b7647bd8 sp bfe854b0 error 7 in libpthread-2.15.so[b763f000+17000]
经过一番谷歌搜索后,我遇到了https://bugs.launchpad.net/ubuntu/+source/apache2/+bug/1159748,这是Ubuntu Apache发行版中确认的错误。我很高兴我不疯了!如果其他人遇到此问题,请务必遵循此错误的进展。