# HDD Fan control
[![PyPI version](https://img.shields.io/pypi/v/hddfancontrol.svg?style=flat)](https://pypi.python.org/pypi/hddfancontrol/)
[![AUR version](https://img.shields.io/aur/version/hddfancontrol.svg?style=flat)](https://aur.archlinux.org/packages/hddfancontrol/)
[![Tests status](https://github.com/desbma/hddfancontrol/actions/workflows/ci.yml/badge.svg)](https://github.com/desbma/hddfancontrol/actions/)
[![Coverage](https://img.shields.io/coveralls/desbma/hddfancontrol/master.svg?style=flat)](https://coveralls.io/github/desbma/hddfancontrol?branch=master)
[![Lines of code](https://tokei.rs/b1/github/desbma/hddfancontrol)](https://github.com/desbma/hddfancontrol)
[![Supported Python versions](https://img.shields.io/pypi/pyversions/hddfancontrol.svg?style=flat)](https://pypi.python.org/pypi/hddfancontrol/)
[![License](https://img.shields.io/github/license/desbma/hddfancontrol.svg?style=flat)](https://github.com/desbma/hddfancontrol/blob/master/LICENSE)
HDD Fan control is a command line tool to dynamically control fan speed according to hard drive temperature on Linux.
This has 3 benefits:
- it allows maintaining your hard drives in the ideal temperature range to have maximum longevity and avoid overheating
Because fans will slow down or stop when not needed:
- it minimizes noise generated by the fans
- it also minimizes power consumption at the same time
## When is this useful?
HDD Fan control is useful when you have one or several hard drives with one or several fans close to them, and do not want to let the motherboard control the fan speed, because it does so either statically, or using a temperature sensor unrelated to the real drive temperature (either on the CPU or on some other place on the motherboard).
The ideal use case is for a NAS with several hard drives, a low power CPU (ie. ARM or Intel Atom) with passive cooling (no fans), and a chassis with fans close to the hard drive. It that case the CPU will generate less heat than the hard drives and it makes sense to control fan speed according to the main heat source.
## Features
- Can run in daemon mode
- Can control several fans and/or several drives with a single invocation
- Supports 6 different ways of querying temperature:
- `hddtemp` invocation
- `hddtemp` daemon query
- `hdparm` invocation
- `smartctl` invocation (SCT)
- `smartctl` invocation (SMART attributes)
- `drivetemp` native kernel hwmon
- Can automatically spin down drives after a customizable period of inactivity
- Can adapt to different fan characteristics
- Can be set to stop fans or run them at full speed at customizable temperatures
- Can be configured to never set the fans below a certain speed (useful if the fans controlled by HDD Fan control are the only ones available in the chassis)
- Can also optionally monitor CPU temperature, and control fan speed accordingly
## Prerequisites
- A Linux distribution
- A least one SATA hard drive\*, that supports:
- Temperature querying
- Power state querying
- A motherboard which:
- exposes to the OS a PWM to control fan speed
- exposes to the OS a sensor to query fan speed
Most motherboards and SATA drives fit these requirements.
\* There has been reports of `hddfancontrol` working well with SAS drives, however this has not been thoroughly tested.
## Installation
HDD Fan control requires [Python](https://www.python.org/downloads/) >= 3.6.
### Distribution packages
Some Linux distributions have a hddfancontrol package available in their repository:
- Arch Linux (AUR): [hddfancontrol](https://aur.archlinux.org/packages/hddfancontrol/)
- Fedora: [hddfancontrol](https://apps.fedoraproject.org/packages/hddfancontrol) (thanks to [TC01](https://github.com/TC01))
### From PyPI (with PIP)
1. If you don't already have it, [install pip](https://pip.pypa.io/en/stable/installing/) for Python 3
2. Install HDD Fan control: `pip3 install hddfancontrol`
3. Install [hdparm](http://sourceforge.net/projects/hdparm/) and [hddtemp](http://www.guzu.net/linux/hddtemp.php) or [smartctl](https://www.smartmontools.org/).
On recent Ubuntu and other Debian derivatives: `sudo apt-get install hdparm smartmontools`.
### From source
1. If you don't already have it, [install setuptools](https://pypi.python.org/pypi/setuptools#installation-instructions) for Python 3
2. Clone this repository: `git clone https://github.com/desbma/hddfancontrol`
3. Install HDD Fan control: `python3 setup.py install`
4. Install [hdparm](http://sourceforge.net/projects/hdparm/), [smartctl](https://www.smartmontools.org/) and optionally [hddtemp](http://www.guzu.net/linux/hddtemp.php).
On recent Ubuntu and other Debian derivatives: `sudo apt-get install hdparm smartmontools`.
To query fan characteristics, you may also need pwmconfig. On Ubuntu and other Debian derivatives, it is part of the fancontrol package, that you can install with `sudo apt-get install fancontrol`. HDD fancontrol and fancontrol are unrelated. The fancontrol daemon is **not** needed for HDD fan control to operate. If you use both fancontrol and HDD fancontrol, be careful not to make them control the same fans.
## Configuration
### A word of caution
The default parameters will run fans at 100% speed at temperatures > 50°C, and run them a 20% speed if < 30°C, which corresponds to the usual recommended drive operating temperature. If you are sure that there are no other components in your system that generate significant heat, if you have other fans to cool down your system, or if you have a case optimized for passive cooling, you can set minimum speed to 0%, which will stop the fans if temperature is below the minimum threshold.
**Be aware that a misconfiguration of this tool can lead to a failure to cool down your system properly which can damage components or reduce their lifetime.**
Before using HDD Fan control unmonitored for long period of time, I recommend keeping a minimum fan speed for security, and checking that the temperature of your system stays in reasonable range as expected.
### Fan configuration
To get the value for the `--pwm`, `--pwm-start-value` and `--pwm-stop-value` parameters, you can either:
- Use the `-t` or `--test` parameter, which will run some tests and detect the values at which the fans start and stop. However you need to have previously identified the PWM file (the `--pwm` parameter)
- use the [pwmconfig tool](http://www.lm-sensors.org/wiki/man/pwmconfig).
### Drive auto spin down
SATA drives can be configured to automatically spin down after a certain period of inactivity, which saves power. If your drives are configured to do so, you may notice that they do not spin down when HDD Fan control is running.
This is due to the fact that HDD Fan control will query temperature at fixed interval, which the drive will consider an activity and reset the spin down timeout.
To fix that, you can either:
- Use a value for the `-i`/`--interval` parameter higher than your SATA spin down time (not recommended unless your spin down time is very low, ie < 2 min). In that case you do not need to use hddfancontrol's `--spin-down-time` switch, because the builtin SATA drive timeout (that you can set for example with [`hdparm -S XXX` command](https://linux.die.net/man/8/hdparm)) should take effect.
- Use the `--spin-down-time` parameter that will monitor drive activity and spin it down if inactive, independantly of the SATA feature (recommended)
**Keep in mind that spinning down and up a drive repeatedly wears it prematurly, so unless you are in a power constrained environement (ie. laptop), do not set the spin down time too low.**
Reading temperature while a drive is in low power state will make it spin up, so HDD Fan control will stop querying temperature in that case, and wait for the drive (which will be cooling down in low power state anyway) to spin up.
Some HGST (previously Hitachi) drives support a special way of querying temperature that does not spin up drives, which HDD Fan control will detect and use, however it still prevents them from spinning down, so the above instructions still apply.
## Command line usage
Run `hddfancontrol -h` to get full command line reference.
As an example, the command line below will instruct HDD Fan control to:
- monitor temperature of drives `/dev/sda` and `/dev/sdb`
- control fan speed using PWM 2 and 3 in `/sys/class/hwmon/hwmon1/device/`
- start both fans using PWM value 200
- consider the fans will stop with PWM value 75
- never run the fans below 10% of their maximum speed
- check temperature at least every minute
- automatically spin down drives if they are inactive for 2 hours (7200 seconds)
- run in daemon mode
- log what is going on to `/var/log/hddfancontrol.log`
`hddfancontrol -d /dev/sda /dev/sdb -p /sys/class/hwmon/hwmon1/device/pwm2 /sys/class/hwmon/hwmon1/device/pwm3 --pwm-start-value 200 200 --pwm-stop-value 75 75 --min-fan-speed-prct 10 -i 60 --spin-down-time 7200 -b -l /var/log/hddfancontrol.log`
## Systemd service
A systemd service file is provided to control the daemon easily.
If you installed hddfancontrol from a distribution package, you likely already have it installed, otherwise you can install it from the sources of this repository with:
```
sudo cp ./systemd/hddfancontrol.service /etc/systemd/system/
sudo mkdir -p /etc/conf.d
sudo cp ./systemd/hddfancontrol.conf /etc/conf.d/hddfancontrol
```
Then you need to edit the `HDDFANCONTROL_ARGS` variable in `/etc/conf.d/hddfancontrol` to set the parameters (drives, temperature range...).
You can then start the daemon with `sudo systemctl start hddfancontrol`, see its status with `sudo systemctl status hddfancontrol` and enable automatic startup at boot time with `sudo systemctl enable hddfancontrol`.
## OpenRC service
An OpenRC service file is provided to control the daemon easily.
If you installed hddfancontrol from a distribution package, you likely already have it installed, otherwise you can install it from the sources of this repository with:
```
sudo cp ./openrc/hddfancontrol /etc/init.d/
sudo mkdir -p /etc/conf.d
sudo cp ./systemd/hddfancontrol.conf /etc/conf.d/hddfancontrol
```
Then you need to edit the `HDDFANCONTROL_ARGS` variable in `/etc/conf.d/hddfancontrol` to set the parameters (drives, temperature range...).
You can then start the daemon with `sudo rc-service hddfancontrol start`, see its status with `sudo rc-service hddfancontrol status` and enable automatic startup at boot time with `sudo rc-update add hddfancontrol default`.
## License
[GPLv3](https://www.gnu.org/licenses/gpl-3.0-standalone.html)
Raw data
{
"_id": null,
"home_page": "https://github.com/desbma/hddfancontrol",
"name": "hddfancontrol",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "hdd, drive, temperature, fan, control, speed",
"author": "desbma",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/b8/71/f2add0ee2e2604fedce848de5dfa62df6371cf5197255be96833ad53f370/hddfancontrol-1.6.2.tar.gz",
"platform": null,
"description": "# HDD Fan control\n\n[![PyPI version](https://img.shields.io/pypi/v/hddfancontrol.svg?style=flat)](https://pypi.python.org/pypi/hddfancontrol/)\n[![AUR version](https://img.shields.io/aur/version/hddfancontrol.svg?style=flat)](https://aur.archlinux.org/packages/hddfancontrol/)\n[![Tests status](https://github.com/desbma/hddfancontrol/actions/workflows/ci.yml/badge.svg)](https://github.com/desbma/hddfancontrol/actions/)\n[![Coverage](https://img.shields.io/coveralls/desbma/hddfancontrol/master.svg?style=flat)](https://coveralls.io/github/desbma/hddfancontrol?branch=master)\n[![Lines of code](https://tokei.rs/b1/github/desbma/hddfancontrol)](https://github.com/desbma/hddfancontrol)\n[![Supported Python versions](https://img.shields.io/pypi/pyversions/hddfancontrol.svg?style=flat)](https://pypi.python.org/pypi/hddfancontrol/)\n[![License](https://img.shields.io/github/license/desbma/hddfancontrol.svg?style=flat)](https://github.com/desbma/hddfancontrol/blob/master/LICENSE)\n\nHDD Fan control is a command line tool to dynamically control fan speed according to hard drive temperature on Linux.\n\nThis has 3 benefits:\n\n- it allows maintaining your hard drives in the ideal temperature range to have maximum longevity and avoid overheating\n\nBecause fans will slow down or stop when not needed:\n\n- it minimizes noise generated by the fans\n- it also minimizes power consumption at the same time\n\n## When is this useful?\n\nHDD Fan control is useful when you have one or several hard drives with one or several fans close to them, and do not want to let the motherboard control the fan speed, because it does so either statically, or using a temperature sensor unrelated to the real drive temperature (either on the CPU or on some other place on the motherboard).\n\nThe ideal use case is for a NAS with several hard drives, a low power CPU (ie. ARM or Intel Atom) with passive cooling (no fans), and a chassis with fans close to the hard drive. It that case the CPU will generate less heat than the hard drives and it makes sense to control fan speed according to the main heat source.\n\n## Features\n\n- Can run in daemon mode\n- Can control several fans and/or several drives with a single invocation\n- Supports 6 different ways of querying temperature:\n - `hddtemp` invocation\n - `hddtemp` daemon query\n - `hdparm` invocation\n - `smartctl` invocation (SCT)\n - `smartctl` invocation (SMART attributes)\n - `drivetemp` native kernel hwmon\n- Can automatically spin down drives after a customizable period of inactivity\n- Can adapt to different fan characteristics\n- Can be set to stop fans or run them at full speed at customizable temperatures\n- Can be configured to never set the fans below a certain speed (useful if the fans controlled by HDD Fan control are the only ones available in the chassis)\n- Can also optionally monitor CPU temperature, and control fan speed accordingly\n\n## Prerequisites\n\n- A Linux distribution\n- A least one SATA hard drive\\*, that supports:\n - Temperature querying\n - Power state querying\n- A motherboard which:\n - exposes to the OS a PWM to control fan speed\n - exposes to the OS a sensor to query fan speed\n\nMost motherboards and SATA drives fit these requirements.\n\n\\* There has been reports of `hddfancontrol` working well with SAS drives, however this has not been thoroughly tested.\n\n## Installation\n\nHDD Fan control requires [Python](https://www.python.org/downloads/) >= 3.6.\n\n### Distribution packages\n\nSome Linux distributions have a hddfancontrol package available in their repository:\n\n- Arch Linux (AUR): [hddfancontrol](https://aur.archlinux.org/packages/hddfancontrol/)\n- Fedora: [hddfancontrol](https://apps.fedoraproject.org/packages/hddfancontrol) (thanks to [TC01](https://github.com/TC01))\n\n### From PyPI (with PIP)\n\n1. If you don't already have it, [install pip](https://pip.pypa.io/en/stable/installing/) for Python 3\n2. Install HDD Fan control: `pip3 install hddfancontrol`\n3. Install [hdparm](http://sourceforge.net/projects/hdparm/) and [hddtemp](http://www.guzu.net/linux/hddtemp.php) or [smartctl](https://www.smartmontools.org/).\n On recent Ubuntu and other Debian derivatives: `sudo apt-get install hdparm smartmontools`.\n\n### From source\n\n1. If you don't already have it, [install setuptools](https://pypi.python.org/pypi/setuptools#installation-instructions) for Python 3\n2. Clone this repository: `git clone https://github.com/desbma/hddfancontrol`\n3. Install HDD Fan control: `python3 setup.py install`\n4. Install [hdparm](http://sourceforge.net/projects/hdparm/), [smartctl](https://www.smartmontools.org/) and optionally [hddtemp](http://www.guzu.net/linux/hddtemp.php).\n On recent Ubuntu and other Debian derivatives: `sudo apt-get install hdparm smartmontools`.\n\nTo query fan characteristics, you may also need pwmconfig. On Ubuntu and other Debian derivatives, it is part of the fancontrol package, that you can install with `sudo apt-get install fancontrol`. HDD fancontrol and fancontrol are unrelated. The fancontrol daemon is **not** needed for HDD fan control to operate. If you use both fancontrol and HDD fancontrol, be careful not to make them control the same fans.\n\n## Configuration\n\n### A word of caution\n\nThe default parameters will run fans at 100% speed at temperatures > 50\u00b0C, and run them a 20% speed if < 30\u00b0C, which corresponds to the usual recommended drive operating temperature. If you are sure that there are no other components in your system that generate significant heat, if you have other fans to cool down your system, or if you have a case optimized for passive cooling, you can set minimum speed to 0%, which will stop the fans if temperature is below the minimum threshold.\n\n**Be aware that a misconfiguration of this tool can lead to a failure to cool down your system properly which can damage components or reduce their lifetime.**\n\nBefore using HDD Fan control unmonitored for long period of time, I recommend keeping a minimum fan speed for security, and checking that the temperature of your system stays in reasonable range as expected.\n\n### Fan configuration\n\nTo get the value for the `--pwm`, `--pwm-start-value` and `--pwm-stop-value` parameters, you can either:\n\n- Use the `-t` or `--test` parameter, which will run some tests and detect the values at which the fans start and stop. However you need to have previously identified the PWM file (the `--pwm` parameter)\n- use the [pwmconfig tool](http://www.lm-sensors.org/wiki/man/pwmconfig).\n\n### Drive auto spin down\n\nSATA drives can be configured to automatically spin down after a certain period of inactivity, which saves power. If your drives are configured to do so, you may notice that they do not spin down when HDD Fan control is running.\nThis is due to the fact that HDD Fan control will query temperature at fixed interval, which the drive will consider an activity and reset the spin down timeout.\nTo fix that, you can either:\n\n- Use a value for the `-i`/`--interval` parameter higher than your SATA spin down time (not recommended unless your spin down time is very low, ie < 2 min). In that case you do not need to use hddfancontrol's `--spin-down-time` switch, because the builtin SATA drive timeout (that you can set for example with [`hdparm -S XXX` command](https://linux.die.net/man/8/hdparm)) should take effect.\n- Use the `--spin-down-time` parameter that will monitor drive activity and spin it down if inactive, independantly of the SATA feature (recommended)\n\n**Keep in mind that spinning down and up a drive repeatedly wears it prematurly, so unless you are in a power constrained environement (ie. laptop), do not set the spin down time too low.**\n\nReading temperature while a drive is in low power state will make it spin up, so HDD Fan control will stop querying temperature in that case, and wait for the drive (which will be cooling down in low power state anyway) to spin up.\n\nSome HGST (previously Hitachi) drives support a special way of querying temperature that does not spin up drives, which HDD Fan control will detect and use, however it still prevents them from spinning down, so the above instructions still apply.\n\n## Command line usage\n\nRun `hddfancontrol -h` to get full command line reference.\n\nAs an example, the command line below will instruct HDD Fan control to:\n\n- monitor temperature of drives `/dev/sda` and `/dev/sdb`\n- control fan speed using PWM 2 and 3 in `/sys/class/hwmon/hwmon1/device/`\n- start both fans using PWM value 200\n- consider the fans will stop with PWM value 75\n- never run the fans below 10% of their maximum speed\n- check temperature at least every minute\n- automatically spin down drives if they are inactive for 2 hours (7200 seconds)\n- run in daemon mode\n- log what is going on to `/var/log/hddfancontrol.log`\n\n`hddfancontrol -d /dev/sda /dev/sdb -p /sys/class/hwmon/hwmon1/device/pwm2 /sys/class/hwmon/hwmon1/device/pwm3 --pwm-start-value 200 200 --pwm-stop-value 75 75 --min-fan-speed-prct 10 -i 60 --spin-down-time 7200 -b -l /var/log/hddfancontrol.log`\n\n## Systemd service\n\nA systemd service file is provided to control the daemon easily.\nIf you installed hddfancontrol from a distribution package, you likely already have it installed, otherwise you can install it from the sources of this repository with:\n\n```\nsudo cp ./systemd/hddfancontrol.service /etc/systemd/system/\nsudo mkdir -p /etc/conf.d\nsudo cp ./systemd/hddfancontrol.conf /etc/conf.d/hddfancontrol\n```\n\nThen you need to edit the `HDDFANCONTROL_ARGS` variable in `/etc/conf.d/hddfancontrol` to set the parameters (drives, temperature range...).\n\nYou can then start the daemon with `sudo systemctl start hddfancontrol`, see its status with `sudo systemctl status hddfancontrol` and enable automatic startup at boot time with `sudo systemctl enable hddfancontrol`.\n\n## OpenRC service\n\nAn OpenRC service file is provided to control the daemon easily.\nIf you installed hddfancontrol from a distribution package, you likely already have it installed, otherwise you can install it from the sources of this repository with:\n\n```\nsudo cp ./openrc/hddfancontrol /etc/init.d/\nsudo mkdir -p /etc/conf.d\nsudo cp ./systemd/hddfancontrol.conf /etc/conf.d/hddfancontrol\n```\n\nThen you need to edit the `HDDFANCONTROL_ARGS` variable in `/etc/conf.d/hddfancontrol` to set the parameters (drives, temperature range...).\n\nYou can then start the daemon with `sudo rc-service hddfancontrol start`, see its status with `sudo rc-service hddfancontrol status` and enable automatic startup at boot time with `sudo rc-update add hddfancontrol default`.\n\n## License\n\n[GPLv3](https://www.gnu.org/licenses/gpl-3.0-standalone.html)\n",
"bugtrack_url": null,
"license": null,
"summary": "Control system fan speed by monitoring hard drive temperature",
"version": "1.6.2",
"project_urls": {
"Download": "https://github.com/desbma/hddfancontrol/archive/1.6.2.tar.gz",
"Homepage": "https://github.com/desbma/hddfancontrol"
},
"split_keywords": [
"hdd",
" drive",
" temperature",
" fan",
" control",
" speed"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "b871f2add0ee2e2604fedce848de5dfa62df6371cf5197255be96833ad53f370",
"md5": "a7363c91d8e8355098604c9bb70882bb",
"sha256": "474077f31097be00df80c00d269a1e0402c4e59c2f63070f1e33f678aed9ea7d"
},
"downloads": -1,
"filename": "hddfancontrol-1.6.2.tar.gz",
"has_sig": false,
"md5_digest": "a7363c91d8e8355098604c9bb70882bb",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 35536,
"upload_time": "2024-06-16T12:07:49",
"upload_time_iso_8601": "2024-06-16T12:07:49.107475Z",
"url": "https://files.pythonhosted.org/packages/b8/71/f2add0ee2e2604fedce848de5dfa62df6371cf5197255be96833ad53f370/hddfancontrol-1.6.2.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-06-16 12:07:49",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "desbma",
"github_project": "hddfancontrol",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [],
"lcname": "hddfancontrol"
}