我有一个启用了 mod_proxy/mod_proxy_balancer/mod_slotmem_shm/mod_lbmethod_byrequests 的 Apache 2.4.23 配置。
此外,我有多个 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),但第二个看起来可能会导致名称冲突。
有人知道如何解决这个问题吗?
赞美和荣幸召集!使用
我能够将错误追溯到 shmat 调用
AIX 上的 man shmat 揭示了这个秘密:
我在运行从源代码编译的 Apache 的 MacOS 上遇到了类似的错误,事实证明,如果您知道它的含义,该错误实际上是非常具有描述性的。显然有一些围绕共享内存管理的工具(在 Linux 和 OS X 上)。
在我的情况下运行:
给了我一些输出,例如:
...然后再说20个。我试图通过这样做来释放它:
之后错误没有发生并且apache启动了。我希望这对任何人都有帮助,它应该可以在 Linux 和 MacOS 上运行,并且可能在 *nix 上运行。