memmon/disk_monitor.py

62 lines
1.5 KiB
Python
Raw Normal View History

2024-12-21 14:03:39 +01:00
"""
Monitors disk usage and notifies on low
Need to pass the path argument as first, e.g.:
python disk_monitor.py /
"""
import argparse
import logging
import shutil
import time
import config
import lib
logging.basicConfig()
logger = logging.getLogger()
def setup_logging_level(debug=False):
log_level = logging.DEBUG if debug else logging.ERROR
logger.setLevel(log_level)
logger.debug("Debugging enabled")
def parse_args():
parser = argparse.ArgumentParser()
parser.add_argument('path', help="Path to monitor")
parser.add_argument('--debug', dest='debug', action='store_true')
return parser.parse_args()
def get_free_disk_space_g(path):
free_disk_space = shutil.disk_usage(path).free
free_disk_space_g = round(free_disk_space / (1024 ** 3), 1)
return free_disk_space_g
def loop(args):
is_low_disk = False
while True:
free_disk_space_g = get_free_disk_space_g(args.path)
logging.debug(f"Free disk space: {free_disk_space_g} G")
if free_disk_space_g < config.MIN_FREE_DISK_SPACE_G:
if not is_low_disk:
message = f"Less than {config.MIN_FREE_DISK_SPACE_G}G of free disk space available on {args.path}."
logging.warning(message)
lib.send_notification("Disk Space Alert", message)
is_low_disk = True
time.sleep(config.TIME_SLEEP_DISK_S)
def main():
args = parse_args()
setup_logging_level(args.debug)
loop(args)
if __name__ == "__main__":
main()