forked from mapbox/dynamodb-replicator
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathbackup.js
62 lines (50 loc) · 2.01 KB
/
backup.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
var AWS = require('aws-sdk');
var Dyno = require('dyno');
var stream = require('stream');
var zlib = require('zlib');
module.exports = function(config, context, done) {
function next(err) {
if (err) return done(err);
done(null, { size: size, count: count });
}
var primary = Dyno(config);
var s3 = new AWS.S3();
var log = config.log || console.log;
var scanOpts = config.hasOwnProperty('segment') && config.segments ? { Segment: config.segment, TotalSegments: config.segments } : undefined;
if (config.backup)
if (!config.backup.bucket || !config.backup.prefix || !config.backup.jobid)
return done(new Error('Must provide a bucket, prefix and jobid for backups'));
var index = !isNaN(parseInt(config.segment)) ? config.segment.toString() : 0;
var key = [config.backup.prefix, config.backup.jobid, index].join('/');
var count = 0;
var size = 0;
var stringify = new stream.Transform({ objectMode: true });
stringify._transform = function(record, enc, callback) {
var line = Dyno.serialize(record);
setImmediate(function() {
stringify.push(line + '\n');
count++;
callback();
});
};
var data = primary.scanStream(scanOpts)
.on('error', next)
.pipe(stringify)
.on('error', next)
.pipe(zlib.createGzip());
log('[segment %s] Starting backup job %s of %s', index, config.backup.jobid, config.region + '/' + config.table);
s3.upload({
Bucket: config.backup.bucket,
Key: key,
Body: data,
ACL: 'bucket-owner-full-control'
}, function(err) {
if (err) return next(err);
log('[segment %s] Uploaded dynamo backup to s3://%s/%s', index, config.backup.bucket, key);
log('[segment %s] Wrote %s items to backup', index, count);
next();
}).on('httpUploadProgress', function(progress) {
log('[segment %s] Uploaded %s bytes', index, progress.loaded);
size = progress.total;
});
};