Many UPS-es do not support cutting power at all, or ignore the command
to cut the power in certain situations. There was a workaround for that:
instead of powering the machines off, they had to halt, then wait a
reasonable amount of time (during which the UPS should turn off), and
then reboot - in case power came back and the UPS did not power-cycle
This is fragile as you have no idea whether power returned or not and
risk hard power off in the middle of next boot.
Usually, you set it to wait for enough time for the UPS to drain; either
it will drain and power off, or the power is back by then. The risk of
power "having been back, but cut off again just now" is miniscule
compared to the risk of having to manually power the machines on (and by
the way, UPS-es do NOT like to be powered on with no load).
Now that systemd manages the shutdown procedure, I don't know if it's
possible to achieve the same behaviour (and thus make NUT work with
As already mentioned, it is ouside of scope of OS actually. How you did
it before systemd?
It was actually a feature of NUT - and a default and recommended feature
at some moment.
See this, from their FAQ:
And this - https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=835634
(there is a link to an old discussion about implementing this feature).
Now it doesn't work anymore, and I'm trying to find a new solution...
But since it's systemd, maybe we can make this even better!
There were some concerns that it's not a good idea to simply "halt the
system"; what we should do is flush all the drives' cache and unload
their heads, which can only be done *properly* from the kernel. (See
this old Debian bug:
https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=358696 ) So maybe with
systemd, we can actually not simply "halt" the system, but make all the
necessary preparations in order to ensure that cutting power is safe?
So your question is misleading. You did not halt (in proper sense) but
rather left OS lingering before doing halt.
There were some concerns about this not being a "proper halt" (in that
old thread); I thought maybe now it's possible to solve that problem as
well, seeing that systemd is all about removing the need for such
scripts and doing things more properly instead.
>> Short version: is it possible with systemd to have the machine halt,
>> wait for a few minutes and then reboot?
When system halts OS kernel is stopped and control is returned to
firmware. So the only thing you can do is to program firmware to reboot
after some delay.
So the best way to implement this would be in the kernel - implement a
"halt-wait-reboot" function that would do everything correctly...
systemd supports switching back to initramfs instead of directly halting
system. This allows you to implement your logic there after everything
is completely shut down and unmounted (you probably need to unmount old
root manually though). You can even monitor UPS from initramfs and only
reboot when it reports power is back to make it safe.
This may be the best idea without touching the kernel. But it still
can't go through the "proper" halt procedure with syncing and unloading
the drives, correct?..
systemd-devel mailing list