Skip to main content

PyPowerEdgeFan is a Python-based PID fan controller for Dell PowerEdge servers.

Project description

PyPowerEdgeFan

PyPowerEdgeFan is a Python-based PID fan controller for Dell PowerEdge servers.

With PyPowerEdgeFan, the fan speed with be adjusted dynamically based on the CPU temperature. This allows the fan to run at a lower speed when the CPU is cool, reducing noise and power consumption. Another added bonus comparing to a static fan curve is that the fan speed is that it needs less tuning and will reduce the annoying oscillation between two fan speeds.

Disclaimer

This project is not affiliated with Dell in any way.

I have only tested this on a Dell PowerEdge R730xd. It may or may not work on other models.

Adjusting fan speed is potentially dangerous. If the fan speed is too low, the server may overheat and cause damage to the hardware or even objects around the server. Use at your own risk. I highly recommend test the cli tool in shell mode first to make sure the script is working for your scenario before running it in daemon mode.

Installation

Install the package using pip:

pip install poweredge_fan

Set up sensors on Ubuntu

To make sure the required sensors package is installed on Ubuntu, run the following command:

sudo apt-get install lm-sensors

After installing lm-sensors, you can run sensors-detect to configure sensors on your system. It will ask you a series of questions to identify the correct sensors for your hardware:

sudo sensors-detect

Follow the prompts and answer the questions accordingly. You may need to reboot your system after the process is complete to ensure proper functionality.

To make sure your sensors are working properly, run the following command:

sensors

You should see output similar to the following:

coretemp-isa-0000
Adapter: ISA adapter
Package id 0:  +58.0°C  (high = +77.0°C, crit = +87.0°C)
Core 0:        +49.0°C  (high = +77.0°C, crit = +87.0°C)
Core 1:        +47.0°C  (high = +77.0°C, crit = +87.0°C)
Core 2:        +48.0°C  (high = +77.0°C, crit = +87.0°C)
Core 3:        +48.0°C  (high = +77.0°C, crit = +87.0°C)
Core 4:        +49.0°C  (high = +77.0°C, crit = +87.0°C)
Core 5:        +49.0°C  (high = +77.0°C, crit = +87.0°C)
Core 6:        +48.0°C  (high = +77.0°C, crit = +87.0°C)
Core 7:        +47.0°C  (high = +77.0°C, crit = +87.0°C)

coretemp-isa-0001
Adapter: ISA adapter
Package id 1:  +66.0°C  (high = +77.0°C, crit = +87.0°C)
Core 0:        +59.0°C  (high = +77.0°C, crit = +87.0°C)
Core 1:        +57.0°C  (high = +77.0°C, crit = +87.0°C)
Core 2:        +57.0°C  (high = +77.0°C, crit = +87.0°C)
Core 3:        +57.0°C  (high = +77.0°C, crit = +87.0°C)
Core 4:        +54.0°C  (high = +77.0°C, crit = +87.0°C)
Core 5:        +56.0°C  (high = +77.0°C, crit = +87.0°C)
Core 6:        +54.0°C  (high = +77.0°C, crit = +87.0°C)
Core 7:        +55.0°C  (high = +77.0°C, crit = +87.0°C)

PyPowerEdgeFan uses the average of all the core temperatures to determine the fan speed.

Usage

To use PyPowerEdgeFan, run the following command:

poweredge_fan -H <host> -U <username> -P <password>

Replace <host>, <username>, and <password> with the appropriate values for your iDRAC.

Arguments

  • -H, --host: IP address of the iDRAC (required)
  • -U, --username: Username for the iDRAC (required)
  • -P, --password: Password for the iDRAC (required)

Running as a systemd service

To run PyPowerEdgeFan as a systemd service, follow these steps:

  1. Create a file called poweredge_fan.service with the Systemd unit template provided in this repository.

  2. Replace <host>, <username>, and <password> in the poweredge_fan.service file with the appropriate values for your iDRAC.

  3. Copy the poweredge_fan.service file to /etc/systemd/system/:

    sudo cp poweredge_fan.service /etc/systemd/system/
    
  4. Reload the systemd configuration:

    sudo systemctl daemon-reload
    
  5. Enable the service to start at boot:

    sudo systemctl enable poweredge_fan
    
  6. Start the service:

    sudo systemctl start poweredge_fan
    
  7. Check the status of the service:

    sudo systemctl status poweredge_fan
    

Contributing

Contributions to PyPowerEdgeFan are welcome! To contribute, please open an issue or submit a pull request through the GitHub repository.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

poweredge_fan-1.0.4.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

poweredge_fan-1.0.4-py2.py3-none-any.whl (5.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file poweredge_fan-1.0.4.tar.gz.

File metadata

  • Download URL: poweredge_fan-1.0.4.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.4

File hashes

Hashes for poweredge_fan-1.0.4.tar.gz
Algorithm Hash digest
SHA256 fa3b83e197b3610313da70a0defe8d859daa1f9e12624026e42a1a648aba0b1b
MD5 ed05ff8847e94e7505aa3ca8d7b72d13
BLAKE2b-256 28657fd27cbd5b9e85406de3412a0dfbb7e38265462c03cf1e30f7fbdbf72ef6

See more details on using hashes here.

File details

Details for the file poweredge_fan-1.0.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for poweredge_fan-1.0.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6805968017b25eb6f316fdd8b573f14dbf0e2b90c8cc8ea520a453a318482c07
MD5 0f7ad70f74e022f7deda0176524a86fc
BLAKE2b-256 e68179584aa4c12a9f3c03a713ec769d0d0b678d4ecf7db38e442808305077fa

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page