使用Lambda将ndjson写入S3存储桶

时间:2020-09-11 17:53:21

标签: node.js amazon-web-services amazon-s3

我需要将ndjson数据上传到S3存储桶。但我正努力将其传递给S3.putObject()

以下是我的JSON数据:

const responseData = uploadData.data.map((upData) => ({
 date: upData.date,
 time: upData.time,
 url: upData.url,
 test1: test1.id,
 test2: test2,
}));

我正在将上述JSON转换为ndjson

const transformStream = ndjson.stringify();
const outputStream = transformStream.pipe(
 fileSystem.createWriteStream(__dirname + '/data.ndjson')
);
responseData.forEach(function iterator(record) {
 transformStream.write(record);
});
transformStream.end();

现在,如何将数据上传到我的S3存储桶中,请提供帮助,谢谢

1 个答案:

答案 0 :(得分:0)

我能够找到一个整洁的解决方案,而无需ndjson

以下代码会将您的JSON数据转换为ndjson格式(如果数据属于以下类型):

[
  {
    "f1": "somedata",
    "f2": "somedata",
    "f3": "somedata"
  },
  {
    "f1": "somedata",
    "f2": "somedata",
    "f3": "somedata"
  }
]

const transformData = (jsonData) => {
 let res = ''
 for (let i = 0; i < jsonData.length; i++) {
   res += `${JSON.stringify(jsonData[i])}\n`
 }
 return res
}

然后,您只需调用AWS.S3-PutObject函数即可将ndjson数据放入S3(如下):

const result = transformData(Data)

const params = {
  Bucket: bucketName,
  Key: keyName,
  Body: result
}

s3.putObject(params, function () {})
// If you need to get the version ID of the Object (only if versioning is Enabled)
// const verID = (await s3.putObject(params, function () {}).promise()).VersionId