On Do, 31.10.24 10:20, Steve Traylen (steve.traylen@xxxxxxx) wrote: > > Hi, > > I was trying to suppress user scope units that are considered failed due to > them requiring a SIGKILL. Typical log might be. > > Oct 30 10:27:55 node989.example.ch systemd[1]: session-3804.scope: Killing > process 1550946 (node) with signal SIGKILL. > Oct 30 10:29:25 node989.example.ch systemd[1]: session-3804.scope: Still > around after SIGKILL. Ignoring. > Oct 30 10:29:25 node989.example.ch systemd[1]: session-3804.scope: Failed > with result 'timeout'. > Oct 30 10:29:25 node989.example.ch systemd[1]: session-3804.scope: Consumed > 1min 30.745s CPU time. > > I doubt increasing the timeout will help. I had thought that a > > # /etc/systemd/system/user-.slice.d/ignore-timeout.conf > > [Slice] > SuccessExitStatus=SIGKILL > > might help but alas SuccessExitStatus can only be set on a services it > seems. SuccessExitStatus is really just about process exit statuses, i.e. about the waitid() info that the service manager will see for the main service process. In your case the scope fails due to the timeout, not because the service would exit due to a SIGKILL (after all, it *doesn*t exit even though the SIGKILL was sent). Note that a process that is unkillable even by SIGKILL usually indicates some driver/kernel bug. Unkillable processes are not the norm on Linux. I am not entirely sure what we are trying to do? You don't want to see the losg about the scope not going away? We don#t support suppressing such logs for scope units. Or are you concerned that these .scope units stick around? Well, they do that because they still contain a process. We do not support a mechanism to hide units that still have running processes, sorry. And I am pretty sure we should not support this. I'd recommend figuring out why these processes do not react to SIGKILL instead of hiding the issue. Lennart -- Lennart Poettering, Berlin