由于内核无法分叉,多个 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,但它却让我更难看到当前正在监听哪些端口。