在Node.js中,我试图通过使用fs.createReadStream
和fs.createWriteStream
方法循环遍历数组来检索对象。
AWS文档显示了如何使用检索单个对象
s3.getObject(params).createReadStream().pipe(file);
但是将params和s3设为
const params = { Bucket:'user_events' };
const s3 = new AWS.S3();
当我打电话给我的功能时:
function gets3Objects(eventsArray) {
console.log('--> finding files from s3...');
const arrLen = eventsArray.length;
let iter = 0;
s3.listObjects(params, (err, data) => {
for (let i = 0; i < arrLen; i += 1) {
let file = eventsArray[i];
params.Key = file;
let fileOut = fs.createWriteStream(`./tmp/${file}`);
let stream = s3.getObject(params).createReadStream().pipe(fileOut);
console.log(i, arrLen, eventsArray[i]);
stream.on('close', () => {
iter += 1;
console.log(`${i} -- file added: ${eventsArray[i]}`);
if (iter === arrLen) {
console.log('-- success! --');
delete params.Key;
return;
}
});
});
}
输出产生:
--> finding files from s3...
0 9 'harry_test_audio_09.wav'
1 9 'harry_test_audio_08.wav'
2 9 'harry_test_audio_07.wav'
3 9 'harry_test_audio_06.wav'
4 9 'harry_test_audio_05.wav'
5 9 'harry_test_audio_04.wav'
6 9 'harry_test_audio_03.wav'
7 9 'harry_test_audio_02.wav'
8 9 'harry_test_audio_01.wav'
6 -- file added: harry_test_audio_03.wav
8 -- file added: harry_test_audio_01.wav
7 -- file added: harry_test_audio_02.wav
0 -- file added: harry_test_audio_09.wav
5 -- file added: harry_test_audio_04.wav
1 -- file added: harry_test_audio_08.wav
3 -- file added: harry_test_audio_06.wav
4 -- file added: harry_test_audio_05.wav
2 -- file added: harry_test_audio_07.wav
-- success! --
其中9个文件的名称正确,每个文件只包含第一个文件的内容。
我也尝试使用stream.on('finish' ...
和stream.on('end' ...
,但结果相似。
我做错了什么?
答案 0 :(得分:1)
我遇到了同样的问题,这是由于循环中的错误关闭造成的。 解决方案是创建一个在所有迭代中都不共享的参数副本。
function gets3Objects(eventsArray) {
console.log('--> finding files from s3...');
const arrLen = eventsArray.length;
let iter = 0;
s3.listObjects(params, (err, data) => {
for (let i = 0; i < arrLen; i += 1) {
let fileParams = {
Bucket: 'user_events',
Key: eventsArray[i]
}
let fileOut = fs.createWriteStream(`./tmp/${file}`);
let stream = s3.getObject(fileParams).createReadStream().pipe(fileOut);
console.log(i, arrLen, eventsArray[i]);
stream.on('close', () => {
iter += 1;
console.log(`${i} -- file added: ${eventsArray[i]}`);
if (iter === arrLen) {
console.log('-- success! --');
return;
}
});
}
});
}