问题现象

在ECS实例中启动某个服务进程时,系统提示task: Cannot allocate memory错误,如下图所示。Cannot allocate memory

可能原因

可能是系统进程数超限导致。

Linux内核通过内核配置参数kernel.pid_max限制进程的数量,当运行的服务的总进程数超出kernel.pid_max的值时,再创建新进程时系统会报错task: Cannot allocate memory
说明 当系统当前已运行的进程数超过最大进程数(kernel.pid_max)的三分之二时,建议您立即调高kernel.pid_max的值,避免影响后续的业务运行。

解决方案

您可以参考以下步骤,根据实际需要调高kernel.pid_max的值(即允许系统运行更多的进程数)。
说明 64位系统允许设置的kernel.pid_max最大值为222,32位系统允许设置的kernel.pid_max最大值为32,768。
  1. 远程连接ECS实例。
    具体操作,请参见连接方式概述
  2. 执行以下命令,查看系统当前已运行的进程数是否大于最大进程数。
    • 查看系统当前已运行的进程数。
      ps -eLf | wc -l
    • 查看系统的最大进程数。
      sysctl kernel.pid_max

    如果系统已运行的进程数大于最大进程数,请继续执行步骤3

  3. 将命令中的XXXX修改为期望值,来调高kernel.pid_max的值。
    • 执行以下任意一条命令,临时设置(重启实例后会失效,需要重新设置)
      • sysctl -w kernel.pid_max=XXXX
      • echo XXXX> /proc/sys/kernel/pid_max
    • 永久设置(不受实例状态影响,一直有效)
      echo "kernel.pid_max=XXXX" >> /etc/sysctl.conf
      sysctl -p
    调高后,系统立即生效。