home |
electronics |
toolbox |
science club |
tuxtalk |
photos |
e-cards |
online-shop
The Linux server shutdown button
I run a little server at home. It runs the print server, a web server, a file server. It sits in the corner without keyboard or monitor and we shut it down unless we need it.
To make it easy for the whole family to safely shut it down this Linux server has a few "shutdown button" options:
- A dedicated physical button connected via an Rs232 to USB adapter. When the server is on
the LED on the button is blinking periodically and if one presses the button it will shutdown + power off.
- A little web page where one can press a button to initiate the shutdown + power off.
- The power button is configured to shutdown and power off the server.
Configure the power button to run shutdown + power off
If you install Ubuntu server and then pressing the power button while the server is running
might already case the server to safely power down. Try to see what it does. It depends on
whether or not you are running a desktop and other configuration options but it might work
right out of the box.
If not the check the following things.
The power button generates an ACIP event and you need to have acpid installed and running
to act on it (install acpid: apt-get -y install acpid).
The acpid will run the script /etc/acpi/powerbtn.sh when the power button is pressed.
Normally /etc/acpi/powerbtn.sh will just perform a few checks to see if it has to pass that
button press information to somebody else. Most of the time that is systemd-logind.
You can however short-circuit the chain and simply add at the top of /etc/acpi/powerbtn.sh:
/sbin/shutdown -h now "Power button pressed"
exit 0
If systemd is running then /etc/acpi/powerbtn.sh might pass the event to systemd-logind.
In that case you don't have to change anything in /etc/acpi/powerbtn.sh.
You can change systemd configuration to do the shutdown. For this you edit
/etc/systemd/logind.conf and you put into that file HandlePowerKey=poweroff
Like this:
[Login]
# ...
HandlePowerKey=poweroff
# ...
Possible actions are "poweroff", "ignore", "reboot", "halt", "kexec",
"suspend", "hibernate", "hybrid-sleep", and "lock". See "man logind.conf"
for further details.
A simple physical shutdown button connected via USB
This is a project that I did first in the year 2000 when PCs had still physical RS232 interfaces
and the power button was a hard power off without any acpi event.
A lot of things have changed since then but this is still a pretty good option. Especially since
it involved also an additional LED where you can see that the server is actually alive and running.
This is very useful when there is no monitor attached. It is also good to have a separate button
for shutdown which give you direct feedback. The power button, when pressed does not do anything
immediately since it takes possibly 10-15 sec until the power LED goes really off.
This button is very easy to build. You need a USB to RS232 adapter, a LED, push button and a 1K resistor.
The total cost is about 5 dollar US if you order the USB to RS232 adapter in china.
Below are pictures and a circuit diagram explaining how to build this. The "driver" software, shutdown-button-rs232-0.1.tar.gz, for download at the end of this article, contains further instructions.
Note: You might have to test different USB to serial adapters. I have recently found some that seem to have only the Tx/Rx lines connected and do not support hardware flow control. All of them were adapters based on the CH341 chip. Try to use adapters with a PL2303 or a FT232 chip.
You can also buy a little USB adapter with just a board. Make sure it has the DTR and CTS pins. That is
what we use. A lot of those small boards have only TX + RX pins and that will not be enough. We use
the RS232 flow control pins for this project.
RS232 pinout:
9 PIN-connector |
25 PIN-connector |
Name |
Dir |
Description |
1 |
8 |
CD |
input |
Carrier Detect |
2 |
3 |
RXD |
input |
Receive Data |
3 |
2 |
TXD |
output |
Transmit Data |
4 |
20 |
DTR |
output |
Data Terminal Ready |
5 |
7 |
GND |
-- |
System Ground |
6 |
6 |
DSR |
input |
Data Set Ready |
7 |
4 |
RTS |
output |
Request to Send |
8 |
5 |
CTS |
input |
Clear to Send |
9 |
22 |
RI |
input |
Ring Indicator |
A web page to shutdown the server remotely
Here is a 3rd option to shutdown a server at home or inside a trusted zone. It uses a
small web server written in perl and listening to port 88. The installation is simple. This is just
one file plus some configuration files for systemd.
Of course you could use ssh and then the shutdown command but this is designed such that even people
without any computer knowledge can do it.
All the software is available below.
References
Shutdown button usage
I have now been using the above solutions on my new server for a few month and here is my conclusion.
Normally we shutdown the server last. In the evening we power down the PCs and afterwards the server. That means the web based shutdown button is not too useful.
Using the power-on button for power off is confusing because it takes a time until the server shuts down. When you power the server on there is an LED that goes on immediately to indicate that the server is starting but there is no indication when you use this button to power it down.
The RS232 based button is the best. It gives feedback. You know if you pressed it properly and it is easy to use.
© 2004-2025 Guido Socher