Bundle hd-idle
application to run in a docker environment.
- Maintained by Patrick Weiss
- Problems and issues can be filed on the Github repository
Like some of my work? Buy me a coffee ☕ (or more likely a beer 🍺, or even more likly shoes 👠 or purse 👜 for the wify 😄)
hd-idle
is a utility program for spinning-down external disks after a period of idle time. Since most external IDE disk enclosures don't support setting the IDE idle timer, a program like hd-idle is required to spin down idle disks automatically.
The goal of this docker image is to make the use of hd-idle
an easy. The configuration of the application can either be done via environment variables or via a config file in a mounted volume.
The image implements the 2 available hd-idle versions:
-
The Golang implementation by Andoni del Olmo. The documentation and source code can be found on Github repository page.
-
The orignal (legacy) implementation by Christina Mueller. The documentation can be found on the Sourceforge page. This version can be used by setting
LEGACY=1
environment variable.
For any configuartion topics concerning hd-idle
I recommend visiting either project site.
Many thanks to to both of them for this great tool!
-
1.2.2
,latest
: Golang version 1.13 and legacy version 1.05 -
dev
: Development build
In order to set the disks in stand-by the container needs to be in privileged
mode and the /dev
path has to be forwarded to the container. Of course that could be a potential security risk. For me personally, I can live with it in my homelab setup.
docker run -d \
--name hd-idle \
--privileged \
-v /dev:/dev \
tekgator/docker-hd-idle:latest
This will run the container with default settings, no configuration possible. All Hard drives will spin down after 10 minutes inactivity.
docker run -d \
--name hd-idle \
--privileged \
-v /dev:/dev \
-v /path_to_config/hd-idle:/config \
tekgator/docker-hd-idle:latest
On first start of the container it will create a config file in the provided volume. Make adjustments as described in the hd-idle
documentation and restart the container afterwards to apply the changes.
docker run -d \
--name hd-idle \
--privileged \
-v /dev:/dev \
-e IDLE_TIME='0' \ # Optional: set default stand-by for all disks, e.g. 0 for turn off
-e DISK_ID1='/dev/disk/by-uuid/994dffb1-96f0-4440-9ee1-4711' \
-e IDLE_TIME1='900' \ # Optional (default 600s): if disk is idle 900s go into stand-by
-e DISK_CMD1='ata' \ # Optional (default: scsi): which API to use to communicate with the device (not evaluated in legacy version)
-e DISK_ID2='/dev/disk/by-uuid/fa376393-91e4-4d9f-8914-4712' \
tekgator/docker-hd-idle:latest
Configurations for certain disks can be made by utilizing environment variables. For each disk setting just increase the number on the variable, e.g. if you like to add a third disk to the config just add DISK_ID3 and so on.
In this example we are creating the following config:
- Turn off stand-by for all disks by using
IDLE_TIME='0'
- Create a special stand-by rule for
DISK_ID1='/dev/disk/by-uuid/994dffb1-96f0-4440-9ee1-4711'
with stand-by time after 15 minutes by utiliztingIDLE_TIME1='900'
. To set the disk into stand-by the ATA command set is usedDISK_CMD1=ata
. - Create a special stand-by rule for
DISK_ID2='/dev/disk/by-uuid/fa376393-91e4-4d9f-8914-4712'
with stand-by time after 10 minutes as default time.
Just combine option 1 and 2 togehter. At first start up a config file is created in the mounted volume with the passed environment variables. Afterwards the config file can be adjusted to your needs. As mentioned already the config file will be parsed on container startup.
If you like to use the legacy hd-idle version you can achive this by setting the environment variable LEGACY=1
like so:
docker run -d \
--name hd-idle \
--privileged \
-v /dev:/dev \
-e LEGACY='1' \
tekgator/docker-hd-idle:latest
Note: If you previously utilized the flags -c
and -s
from the Golang version it needs to be removed from the config. Otherwise legacy hd-idle
will not start. But this can also be seen in the log.
A sample docker-compose file can be found within the repository. Also the test cases are worth a look.
hd-idle:
image: tekgator/docker-hd-idle:latest
container_name: hd-idle
privileged: true
environment:
# LEGACY: 1 #uncomment to use legacy version of hd-idle
IDLE_TIME: 0
DISK_ID1: /dev/disk/by-uuid/994dffb1-96f0-4440-9ee1-4711
DISK_CMD1: ata
IDLE_TIME1: 900
DISK_ID2: /dev/disk/by-uuid/fa376393-91e4-4d9f-8914-4712
volumes:
- /dev:/dev
- ./config:/config
restart: unless-stopped
- Shell access whilst the container is running:
docker exec -it hd-idle /bin/bash
- To monitor the logs of the container in realtime:
docker logs -f hd-idle