gpt4 book ai didi

ibm-mq - MQ进程amqrmppa不断增加

转载 作者:行者123 更新时间:2023-12-01 23:17:00 26 4
gpt4 key购买 nike

美好的一天。

我遇到一个问题,MQ 进程 amqrmppa 不断增加,目前有 635 个进程存在。前 2 天它只有 2++ 个进程,但一直缓慢增加直到当前值。

MQ 版本 = 8.0

操作系统 = AIX 7

此进程预计会增加,直到我们的 maxuproc 限制为 1024。

当我运行命令时,

echo "dis chs(*)" | runmqsc MYMQ | grep channel | wc -l

出现的输出是268。

这是否意味着 amqrmppa 使用的实际进程是 268?

最佳答案

amqrmppa 进程是 MQ 的 channel 池进程,默认情况下将使用线程和新进程实例进行扩展。当它像这样增加时,有两种可能性。

  1. 内存泄漏。这个问题没有提到完整的版本号。当包含修复包级别时,它将是点分四边形格式,例如 8.0.0.1,其中 8.0 是主要版本,0.1 是支持流和 Fix Pack。当修复包已知时,可以通过 APARS 查看它是否是已知问题。
  2. 应用程序错误。当应用程序不正确地终止客户端连接时,它会留下一个孤立的 channel 实例。这些最终会超时,但是池化过程释放线程的速度很慢,因为重用一个线程比从头开始重建整个过程要快。因此,流程数量通常反射(reflect)了最近启动 channel 的高水位线。

通常,糟糕的编程或外部因素(如防火墙超时)比 MQ 代码错误更可能是根本原因,但每个 Fix Pack 中的 APARS 数量证明这些确实会发生。您可能想要调整 MAXCHAN 设置,以便没有一个应用程序可以启动超过合理数量的并发 channel 实例。您可能还想安装 BlockIP2LogIP(来自 Mr. MQ)并记录连接尝试。

一些注意事项:

  • 通常,由于将 channel 分派(dispatch)给线程,进程数少于并发 channel 数。不过这是可调的,本地 QMgr 可能会将 channel 设置为 PROCESS 而不是 THREAD。此外,如果 channel 由 inetd 启动,则结果是每个进程一个 channel 。 (在现代 QMgr 中不要这样做!)
  • 为什么要使用 maxuproc=1024 运行?根据 MQ v8.0 的信息中心,on AIX this value should be 64000 .如果未执行推荐的内核调整,明显的进程泄漏是您可能会看到的最良性错误之一。运行 mqconfig 程序并按照它给出的建议进行操作。 (我相信 mqconfig 在 AIX 上运行,您还需要为它提供可执行文件的完整路径名。)

关于ibm-mq - MQ进程amqrmppa不断增加,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42818464/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com