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=1environment 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:latestThis 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:latestOn 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:latestConfigurations 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:latestNote: 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 
