-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbackup_audit.py
executable file
·81 lines (75 loc) · 2.64 KB
/
backup_audit.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#!/usr/bin/python
import sys
import json
import time
import datetime
import psycopg2
import logging
import logging.handlers
import smtplib
import requests
from docker import Client
import mydb.admin_db as admin_db
import mydb.config as config
from mydb.send_mail import send_mail
"""
audit MyDB backups. Check MyDB Admin backup logs.
verify that each data base in active state has been
backed up.
"""
def check_backup_logs(con_name, c_id, policy, verbose):
""" query backup logs
verify that backup started and ended
verify that backup was run within policy (Daily or Weekly)
"""
if policy == 'Daily':
since = datetime.datetime.now() - datetime.timedelta(days=1)
elif policy == 'Weekly':
since = datetime.datetime.now() - datetime.timedelta(days=7)
result = admin_db.backup_lastlog(c_id)
start_id = end_id = None
for row in result:
if row.state == 'start':
start_ts = row.ts
start_id = row.backup_id
if row.ts < since:
msg = 'Warning: Last backup does not match Policy.'
msg += 'Container: %s Policy: %s Time of last Backup: %s'
print(msg % (con_name, policy, row.ts))
if row.state == 'end':
end_ts = row.ts
end_id = row.backup_id
url = row.url
if start_id and end_id and start_id == end_id: # this is good
duration = end_ts - start_ts
if verbose > 0:
msg = '%-30s %6s duration: %s Start: %s Url:%s'
print(msg % (con_name, policy, duration, start_ts, url))
else:
msg = 'Warning: Backup for <%s> started but did not finish! '
msg += 'Start time: %s'
print(msg % (con_name, start_ts))
def verify_container_backups(verbose):
""" inspect the backup logs for every container that is running.
get list of all "running" containers
inspect backup logs based on backup policy for each container
"""
check_list = []
containers = admin_db.list_containers()
for (c_id, con_name) in containers:
data = admin_db.get_container_data('', c_id)
if 'BACKUP_FREQ' in data['Info']:
policy = data['Info']['BACKUP_FREQ']
else:
print('Extreme Badness: Backup policy not set for %s.' % con_name)
continue
if policy == 'Daily' or policy == 'Weekly':
check_backup_logs(con_name, c_id, policy, verbose)
else:
if verbose > 0:
print('%-30s %s' % (con_name, policy))
if __name__ == '__main__':
verbose = 0
if len(sys.argv) > 1 and sys.argv[1] == '--verbose':
verbose = 1
verify_container_backups(verbose)