我有一个 Apache 2.4.23 配置,其中启用了 mod_proxy/mod_proxy_balancer/mod_slotmem_shm/mod_lbmethod_byrequests。
此外,我有多个 VirtualHost 监听不同的端口,设置如下(PORT 和 COMPONENT 是唯一的):
Listen PORT
<VirtualHost *:PORT>
Include "eib/conf/default-proxy-params"
ErrorLog "logs/PORT-COMPONENT-error.log"
CustomLog "logs/PORT-COMPONENT-access.log" common
<Proxy balancer://COMPONENT/>
BalancerMember https://HOST1:PORT
BalancerMember https://HOST2:PORT
ProxySet lbmethod=byrequests
</Proxy>
ProxyPass / balancer://COMPONENT/ lbmethod=byrequests nofailover=Off maxattempts=3
ProxyPassReverse / balancer://COMPONENT/
</VirtualHost>
当我的配置中只有一个 VirtualHost 条目时,一切都正常。一旦我添加另一个 VirtualHost,Apache 就会崩溃并出现配置失败错误:
[Wed Oct 12 21:59:38.211829 2016] [slotmem_shm:error] [pid 4129010:tid 1] (24)Too many open files: AH02611: create: apr_shm_create(/apache/logs/slotmem-shm-pf3f0916c.shm) failed
[Wed Oct 12 21:59:38.211927 2016] [:emerg] [pid 4129010:tid 1] AH00020: Configuration Failed, exiting
我已检查文件数的 ulimit 设置为无限制,因此这不是问题所在。似乎为 BalancerMemebers 创建的 slotmem 文件之间存在冲突。
当我仅从一个 VirtualHost 开始时,一切都将按预期工作,并且我会创建以下 slotmem 文件:
slotmem-shm-p99964586.shm
slotmem-shm-p99964586_COMPONENT.shm
一个对于虚拟主机来说似乎是唯一的(_COMPONENT),但是第二个看起来可能会导致名称冲突。
有人知道如何解决这个问题吗?
答案1
赞美和荣耀归于盟约者!使用
truss -f apachectl -X
我能够将错误追溯到 shmat 调用
6226262: 45089225: shmat(39845990, 0x00000000, 0) Err#24 EMFILE
AIX 上的 man shmat 揭示了这个秘密:
扩展的 shmat 功能可用。如果定义了环境变量 EXTSHM=ON,则在该环境中执行的进程将能够创建和附加超过 11 个共享内存段。
答案2
我在运行从源代码编译的 Apache 的 MacOS 上遇到了类似的错误,事实证明,如果您知道它的含义,该错误实际上非常具有描述性。显然有一些围绕共享内存管理的工具(在 Linux 和 OS X 上)。
就我的情况来说:
ipcs -m
给了我一些输出,例如:
IPC status from <running system> as of Fri Feb 1 15:43:45 CET 2019
T ID KEY MODE OWNER GROUP
Shared Memory:
m 65536 0x52043973 --rw------- root wheel
m 393217 0xe3046b9b --rw------- myuser1 staff
... 然后再说 20 个。我尝试通过以下方式释放它:
ipcrm -m 393217
之后错误不再发生,apache 启动了。我希望这对任何人都有帮助,它应该可以在 Linux 和 MacOS 上运行,也可能可以在 *nix 上运行。