Hi Harald, Thanks for comprehensive account of the job flow - all worked as expected now. Interestingly, I originally assumed it was a bug due to observed discrepancy with bash... On 29/03/2020 23:07, Jilles Tjoelker wrote: > I agree that the change is incorrect, but I do not agree that this kind > of script must leak memory. Per POSIX.1-2008 XCU 2.9.3.1 Asynchronous > Lists, an implementation has additional ways to forget about jobs than > just an appropriate completion of the wait utility: if another > asynchronous job is started when $! was not referenced or if the number > of known process IDs would exceed {CHILD_MAX} (which tends to be rather > big, though). I can see in Bash man pages: CHILD_MAX Set the number of exited child status values for the shell to remember. Bash will not allow this value to be decreased below a POSIX-mandated minimum, and there is a maximum value (currently 8192) that this may not exceed. The minimum value is system-dependent. Running above scripts under bash shell manifests growing RSS just initially, and with sleep .1 that growth will end after some 800 seconds as one could deduce from the man pages. That is, RSS growth is bound. I understand dash philosophy could be focussed on the most minimalistic solution possible. Such solution would inherently be less forgiving in terms of mistakes. On the other hand, the mistake in question can be difficult to detect and leads all the way to OOM, negatively affecting user experience. It is up to you and community where that balance should rest. And if you decide the change would be worthy of doing - I will be more than happy to contribute. Cheers, Vitaly