#!/usr/bin/env python3 from datetime import datetime, timedelta from re import match from subprocess import check_output from sys import exit output = check_output(['zfs', 'get', 'creation', '-Hpr', '-t', 'snapshot']) now = int(datetime.now().timestamp()) warn_age = now - (60 * 60 * 24 * 90) warn_snapshots = set() return_code = 0 for line in output.decode('utf-8').split("\n"): if line.strip() == '': continue items = line.split("\t") # If the snapshot name contains 'zfs-auto-snap', it's probably # really an automated snapshot and will be cleaned up eventually. # This check only cares about manually created snapshots, though. if 'zfs-auto-snap' in items[0]: continue # SNAPSHOT_FOR_RESET is used by bundle automatic-reset-of-zfs-dataset # to reset datasets to a known good state (used for test systems). if 'SNAPSHOT_FOR_RESET' in items[0]: continue # These are docker-internal snapshots and should not be touched by # us. if match(r'^tank/docker/[a-z0-9]+(-init)?@[0-9]+', items[0]): continue # line should be ' creation -', separated by # tabstops. if len(items) < 3: print('UNKNOWN - error while parsing ' + line) exit(3) creation_date = int(items[2]) if creation_date < warn_age: warn_snapshots.add(items[0]) for snap in sorted(warn_snapshots): print('WARN - {} is older than 90 days'.format(snap)) if len(warn_snapshots) > 0: return_code = 1 else: print('OK - no snapshots are older than 90 days') exit(return_code)