0

首先,版本:

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 内存升级之前,我只有 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 的段错误。

4

2 回答 2

2

这可能与操作系统中某个段允许的共享内存有关,该共享内存可能远低于 256MB。

检查 的输出sudo sysctl kernel.shmmax。在我的 debian 机器上,它是 33554432 (32MB)。

作为一种可能的解决方案。尝试apc.shm_segments在您的 APC 配置中增加到 256 / 32 = 8。您还可以将段系统范围的允许共享内存更改为 256MB。

sudo sysctl -w kernel.shmmax 268435456
于 2013-04-30T20:14:06.617 回答
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 发行版中已确认的错误。我很高兴我没有疯!如果其他人遇到此问题,请务必关注此错误的进度。

于 2013-04-30T23:37:23.840 回答