Skip to main content

Monitors RAM usage and enables swap devices

Project description

SwapDog

SwapDog is a swap watchdog that monitors RAM usage and enables or disables swap devices automatically based on user-defined thresholds. It is designed to prevent excessive swapping, which can lead to performance degradation and SSD wear, while still allowing the system to function without crashing when RAM is exhausted.

Rationale

SwapDog helps you avoid unnecessary swap usage when RAM is available, but will enable swap if memory pressure gets high—and disable it again when pressure drops. This approach is more radical than simply tuning swappiness:

  • Swap memory is always slower than RAM; HDDs are especially slow.
  • SSDs wear out with read and write cycles, while RAM does not.
  • Disabling swap when not needed reduces SSD wear and improves performance.

These reasons are enough for me to want to limit the usage of swap in a more dynamic way than swappiness does.

Installation

Any installation method assumes that you have access to the swapdog.py, swapdog.json, requirements.txt and swapdog.service files in the current directory.

git clone https://github.com/FLAK-ZOSO/SwapDog
cd SwapDog

You may want to proceed with the configuration before installing, but you can also do it later.

Automated

You can use the provided install.sh script to automate the installation process. Just run the following command:

chmod +x install.sh
./install.sh

Manual

Take this as a documentation of the steps that the install.sh script performs, so you can do it manually if you prefer:

  1. Install dependencies with sudo pip3 install -r requirements.txt
  2. Copy the swapdog.py file to /usr/local/sbin/
  3. Make it executable with sudo chmod 744 /usr/local/sbin/swapdog.py
  4. Copy the swapdog.json file to /etc/
  5. Copy the swapdog.service file to /etc/systemd/system/
  6. Enable the service with sudo systemctl enable swapdog
  7. Start the service with sudo systemctl start swapdog
  8. Check the status of the service with sudo systemctl status swapdog
sudo pip3 install -r requirements.txt --break-system-packages
sudo cp swapdog.py /usr/local/sbin/
sudo chmod 744 /usr/local/sbin/swapdog.py
sudo cp swapdog.json /etc/
sudo cp swapdog.service /etc/systemd/system/
sudo systemctl enable swapdog
sudo systemctl start swapdog
sudo systemctl status swapdog

Configuration

In order to configure the behavior of SwapDog, you need to edit the swapdog.json file located in /etc/. The file follows a simple JSON structure that allows you to set thresholds and the swap devices to be used.

Fields

  • thresholds: An array of objects, each representing a threshold for enabling a swap device.
    • percentage: The percentage of RAM usage that triggers the swap device to be enabled.
    • swap: The path to the swap device (e.g., /dev/sda1 or /swapfile).
  • period: The time in seconds between checks of the RAM usage. Default is 1.0 seconds if not specified.
  • disable_swaps: A boolean flag that indicates whether to disable swaps when RAM usage is below the threshold. Default is false.
  • hysteresis: A float value that defines the hysteresis for disabling swaps. This is the percentage below the threshold at which swaps will be disabled. Default is 10.0 if not specified.

How to configure

  • Enable all swaps in order to make them easily detectable.
sudo swapon --all
  • List the currently enabled swap devices.
sudo swapon --show
sudo cat /proc/swaps

What follows is an example output. You are looking for the NAME column to identify the swap devices.

NAME      TYPE      SIZE USED PRIO
/dev/dm-1 partition 7.4G   0B   -2
/swapfile file      2.0G   0B   -3
  • Edit the swapdog.json file to set the desired thresholds and swap devices. For example, if you want to enable a swap device when RAM usage exceeds 95%, you can set it like this:
{
    "thresholds": [
        {
            "percentage": 95.0,
            "swap": "/dev/dm-1"
        },
        {
            "percentage": 90.0,
            "swap": "/swapfile"
        }
    ],
    "period": 1.0,
    "disable_swaps": true,
    "hysteresis": 15.0
}

Uninstallation

To uninstall SwapDog, you can use the provided uninstall.sh script or perform the steps manually.

Automated

You can run the following command to uninstall SwapDog using the script:

chmod +x uninstall.sh
./uninstall.sh

Manual

Take this as a documentation of the steps that the uninstall.sh script performs, so you can do it manually if you prefer:

  1. Stop the service with sudo systemctl stop swapdog
  2. Disable the service with sudo systemctl disable swapdog
  3. Remove the service file with sudo rm /etc/systemd/system/swapdog.service
  4. Remove the script with sudo rm /usr/local/sbin/swapdog.py
  5. Remove the configuration file with sudo rm /etc/swapdog.json
sudo systemctl stop swapdog
sudo systemctl disable swapdog
sudo rm /etc/systemd/system/swapdog.service /usr/local/sbin/swapdog.py /etc/swapdog.json
sudo systemctl daemon-reload

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

swapdog-0.2.2.tar.gz (19.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

swapdog-0.2.2-py3-none-any.whl (18.1 kB view details)

Uploaded Python 3

File details

Details for the file swapdog-0.2.2.tar.gz.

File metadata

  • Download URL: swapdog-0.2.2.tar.gz
  • Upload date:
  • Size: 19.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for swapdog-0.2.2.tar.gz
Algorithm Hash digest
SHA256 2c4e7174f554eeb7913b9fd91583ceaa59a4b61d126b67f10ff9699868d8d4a9
MD5 c72f052c4a3433ea71b81ad855a8f8b3
BLAKE2b-256 02f4ffb8b33048127617b14f0592eb257ab323d5000f917c4cdb92a6b5823ccd

See more details on using hashes here.

Provenance

The following attestation bundles were made for swapdog-0.2.2.tar.gz:

Publisher: python-publish.yml on FLAK-ZOSO/SwapDog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file swapdog-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: swapdog-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 18.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for swapdog-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 eada4197c016fce80d4d146ef7f25383b01ab7d290de85962030586be2eea1c9
MD5 3910942ac69d0a3ed8597c77ebaf1140
BLAKE2b-256 3aa4b83141dfcbce6a641e4b98b87dcb02aa0133a822f51a6f6e1d2fcef870c2

See more details on using hashes here.

Provenance

The following attestation bundles were made for swapdog-0.2.2-py3-none-any.whl:

Publisher: python-publish.yml on FLAK-ZOSO/SwapDog

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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