-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathautomated_rds_snapshots.js
95 lines (84 loc) · 3.2 KB
/
automated_rds_snapshots.js
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#!/usr/bin/env node
var aws = require('aws-sdk');
var _ = require('underscore');
var moment = require('moment');
var winston = require('winston');
winston.remove(winston.transports.Console);
winston.add(winston.transports.File, { filename: '/var/tmp/automated_rds_snapshots.log' });
aws.config.update({
region: 'us-east-1',
//logger: process.stdout
})
var now = moment().format("YYYY-MM-DD-HH");
winston.info('START')
var rds = new aws.RDS();
var rds_instances = [
{
name: 'dwh-metadata',
frequency: 'daily',
keep_days: '14'
}
]
function delete_snapshots(snapshots) {
_.each(snapshots, function (snapshot) {
var params = { DBSnapshotIdentifier: snapshot.DBSnapshotIdentifier };
rds.deleteDBSnapshot(params, function(err, data) {
if (err) winston.info(err, err.stack);
else { winston.info('Deleting expired snapshot: ', snapshot.DBSnapshotIdentifier) }
});
})
}
function delete_expired_snapshots(inst) {
var expire_time = moment().subtract(inst.keep_days, 'minutes').toISOString()
var params = { DBInstanceIdentifier: inst.name, SnapshotType: 'manual' }; // config to find expired snapshots
rds.describeDBSnapshots(
params,
function(err, snapshots) {
if (err) winston.info(err, err.stack);
else {
var expired = _.filter(snapshots.DBSnapshots, function(snapshot){ return moment(snapshot.SnapshotCreateTime).isBefore(moment().subtract(inst.keep_days, 'days')); });
delete_snapshots(expired)
}
}
);
}
function create_snapshot(inst) {
var params = { DBInstanceIdentifier: inst.name, DBSnapshotIdentifier: inst.name + '-' + moment().format("YYYY-MM-DD-HH-mm") };
rds.createDBSnapshot(params, function(err, data) {
if (err) winston.info(err, err.stack);
else { winston.info(data.DBSnapshot.DBSnapshotIdentifier); }
});
}
function create_daily_snapshot(inst) {
// find snapshots less than 1 day old, and if none exist, create new, daily snapshot
var params = { DBInstanceIdentifier: inst.name, SnapshotType: 'manual' };
//console.log(params)
rds.describeDBSnapshots(
params,
function(err, snapshots) {
if (err) winston.info(err, err.stack);
else {
var dailies = _.filter(snapshots.DBSnapshots, function(snapshot){ return moment(snapshot.SnapshotCreateTime).isAfter(moment().subtract(1, 'days')); });
// no daily backup, so make one
if ( dailies == 0 ) {
winston.info('No daily backup')
create_snapshot(inst)
// daily backup exists, so list
} else {
winston.info('Found daily backup')
_.each(dailies, function (snapshot) {
winston.info('id: ' + snapshot.DBSnapshotIdentifier + ', created: ' + moment(snapshot.SnapshotCreateTime).format('YYYY-MM-DD HH:mm'))
})
}
}
}
);
}
/* find and delete expired snapshots */
_.each(
rds_instances,
function (inst) {
delete_expired_snapshots(inst)
create_daily_snapshot(inst)
}
)