AIX 6.1 上的 Apache 2.4,带有 Proxy/BalancerMember 的多个虚拟主机 -> 共享内存 (shm) slotmem 文件存在问题

AIX 6.1 上的 Apache 2.4,带有 Proxy/BalancerMember 的多个虚拟主机 -> 共享内存 (shm) slotmem 文件存在问题

我有一个 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 上运行。

相关内容