错误消息

错误消息

由于内核无法分叉,多个 cron 作业始终无法执行。这种情况已经持续了数周(我想从我升级到 Ubuntu 16 开始,但可能更早)。

错误消息

 $ grep fork myscript.log
/usr/bin/groovy: 24: /usr/bin/groovy: Cannot fork

$ tail /var/log/syslog
Oct 19 14:25:01 nuc CRON[19939]: (CRON) error (can't fork)
Oct 19 14:25:01 nuc cron[719]: /usr/sbin/sendmail: Resource temporarily unavailable

注:我并不特别关心sendmail

环境信息

ulimit -a

time(seconds)        unlimited
file(blocks)         unlimited
data(kbytes)         unlimited
stack(kbytes)        8192
coredump(blocks)     0
memory(kbytes)       unlimited
locked memory(kbytes) 64
process              999999
nofiles              999999
vmemory(kbytes)      unlimited
locks                unlimited
rtprio               0

cat /proc/sys/fs/文件编号

7936    0   793377

猫/ proc / sys /内核/ pid_max

32768

顶部

  1  [|||                                                                                                       1.9%]   Tasks: 196, 114 kthr; 1 running
  2  [|||||                                                                                                     4.2%]   Load average: 0.43 0.20 0.16
  3  [|                                                                                                         0.7%]   Uptime: 2 days, 18:22:08
  4  [                                                                                                          0.0%]
  Mem[|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| 5.68G/7.62G]
  Swp[|||||||                                                                                             218M/3.82G]

uname -a

Linux nuc 4.4.0-21-generic #37-Ubuntu SMP Mon Apr 18 18:33:37 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux

其他相关信息

  • 这似乎大多发生在 cron 中。当我以交互方式运行它时(通常在 中zsh),作业运行良好。
  • 我正在运行数十个 groovy 微服务(并且每个线程都为每个 jar 文件打开自己的文件句柄)。
  • 我出于无奈开始使用 Docker,但它却让我更难看到当前正在监听哪些端口。

相关内容