来自nodejs服务器的响应时间与覆盆子pi上的express非常慢

时间:2017-03-05 21:58:50

标签: node.js http express raspberry-pi raspberry-pi3

TLDR; http响应在Rasberry pi上非常慢,在本地超快速

我有一个raspberry pi 3,在我的本地网络上运行express的nodejs服务器。

服务器总是在后台做一些工作,我做了一个休息api来检查进度。

当调用get时,服务器向我发送一个附有脚本文件的html文件,脚本调用另一个api来获取原始数据并将其注入html文件。 (我这样做,所以我不必在服务器上注入数据)

现在问题出现了:当我在电脑上运行服务器时,一切都很快。但是在我的树莓上发送几乎空的html + js + css文件需要10秒钟。我检查了cpu和ram用法,它总是在50%左右,所以这应该不是问题。

有人知道造成这种情况的原因吗?

work.js

var db = require('./db.js');

var storeCollection;
var allowCollection;
var dbToClose;

module.exports.get = get;

function get(query, callback) {
    db.connect(function(database){
        storeCollection = database.collection(query+"store");
        allowCollection = database.collection(query+"allow");
        dbToClose = database;
        getOne(query, 1, callback);
    });

}
function getOne(query, page, callback) {
    jsdom.env(searchurl + query + pageparam + page, function (err, window) {
        if (err) {
            console.error(err);
            return;
        }
        var $ = jquery(window);
        var resultlist = $("...");
        var count = 0;
        if(resultlist.length <= 0){
            dbToClose.close();
            callback("work");
        }
        for (var i = 0; i < resultlist.length; i++) {
            var item = new Object();

            //data parsing

            if (item.link) {
                item._id = new Buffer(item.link).toString('base64');
                db.addOneIfAllowed(storeCollection,allowCollection,item,function(){
                    if(++count == resultlist.length){
                        getOne(query, ++page, callback);
                    }
                });
            } else{
                dbToClose.close();
                callback("work");
            }
        }
    });
}

web.js

//rest api
...


//work
updateDatabase();
setInterval(updateDatabase, 60000 * 5);

function updateDatabase() {
    timer.start();
    db.connect(function (database) {
        var persist = database.collection("persist");
        persist.find({}).toArray(function (err, persisting) {
            database.close();
            persisting.forEach(function (q) {
                persistAll(q._id);
            });
        });
    });
}

function persistAll(q) {
    var workcount = 0;
    var time;
    function finish(name) {
        console.log("persisted "+name);
        workcount++;
        if (workcount == 6) {
            console.log("done persisting");
        }
    }
    time = Date.now();
    work.get(q, finish);
    otherwork.get(q,finish);
    ...
}

1 个答案:

答案 0 :(得分:0)

听起来你正在饿死IO绑定任务(负责发送响应的部分)。

  

服务器总是在后台做一些工作

做什么工作?小心分享一些代码?

查看setImmediate或查看优秀的async库。