我们在 nodejs(服务器 A)上构建了一个应用程序,它使用 REST API 从另一个 nodejs 应用程序(服务器 B)获取数据。
同样,对于下载文件,服务器 A 在服务器 B 上发出请求,服务器 B 从 AWS S3 获取文件并将数据通过管道传输回服务器 A。
该系统运行良好,我们能够下载高达 1GB 的文件。
问题有时是服务器 A 崩溃并出现以下错误:
buffer.js:488
throw new Error('toString failed');
^
Error: toString failed
at Buffer.toString (buffer.js:488:11)
at Request.<anonymous> (/var/www/sky/portal/node_modules/request/request.js:1145:39)
at emitOne (events.js:95:20)
at Request.emit (events.js:182:7)
at IncomingMessage.<anonymous> (/var/www/sky/portal/node_modules/request/request.js:1091:12)
at IncomingMessage.g (events.js:273:16)
at emitNone (events.js:85:20)
at IncomingMessage.emit (events.js:179:7)
at endReadableNT (_stream_readable.js:913:12)
at _combinedTickCallback (internal/process/next_tick.js:74:11)
at process._tickCallback (internal/process/next_tick.js:98:9)
服务器 A 使用以下代码调用服务器 B:
exports.downloadAsset = function(req, res, assetUrl, cb) {
res.cookie('fileDownload', 'true');
request(
config.api.baseUrl + assetUrl
,
function(error, response, body) {
}
).pipe(res);
}
我们不确定应用程序从哪里崩溃。请建议。