使用node.js应用程序

时间:2016-09-20 09:57:51

标签: node.js concurrency

这是我的web-server示例代码,它承载100MB文件并提供用户下载链接。此应用程序适用于少数下载请求

var http = require('http');
var path = require('path');
var express = require('express');   // The ExpressJS framework
var fs = require('fs');
var console = require('console');

var app = express();
app.set('port', process.env.PORT || 3000);
app.set('view engine', 'ejs');

app.get('/f1', function(req, res){
var filenameWithPath = __dirname+"/uploaded_files/f1";
res.setHeader("content-type", "binary");
console.log(filenameWithPath);
res.download(filenameWithPath, function (err, data) {
    if (err) return console.error(err);
    console.log(data);
    });
  });

app.get('/', function(req, res){
    res.write('This is lift-downloadable app home page');
    res.end();
    });
 var server = http.createServer(app);
 server.listen(app.get('port'), function(){
 console.log('Express server listening on port ' + app.get('port'));
 });  

然而,当我使用脚本运行并发测试时:

#!/bin/bash
cd tmp
rm *
for i in `seq 1 20`;
do
  wget  https://lift-downloadable.mybluemix.net/f1 &
done

它实际上是部分下载文件。观察结果如下: 1)当我们增加并发线程数时,开始下载需要一些时间并且下载开始延迟会增加。 2)因此假设15个下载线程中的2个开始下载,当第3个下载线程开始下载时,前两个下载突然下载,并且所有其他线程跟进后也会在开始下载后突然结束。 3)我也无法在文件下载过程中看到下载大小。它总是说出2MB的未知数。

我已经确认下载速度非常好,因此网络带宽良好,我们在托管此应用程序的服务器上看不到cpu问题的内存。

你能帮忙吗?

0 个答案:

没有答案