node.js - 来自 nodejs 服务器的响应时间在 raspberry pi 上使用 express 非常慢

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

TLDR; http 响应在树莓派上极慢,在本地超快

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

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

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

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

有人知道是什么原因造成的吗?

工作.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");
            }
        }
    });
}

网络.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);
    ...
}

最佳答案

听起来您正在等待 IO 绑定(bind)任务(负责发回响应的部分)。

The server is always doing some work in the background

什么样的工作?愿意分享一些代码吗?

查看 setImmediate或者看看优秀的async图书馆。

关于node.js - 来自 nodejs 服务器的响应时间在 raspberry pi 上使用 express 非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42614581/

相关文章:

JavaScript-类型错误: Cannot read property 'children' of undefined

node.js - async.each/forEach 第三个参数(回调)在每个间隔后触发

javascript - Express 服务器 404ing 所有来自索引的请求

javascript - NodeJS 初学者问题。 "Create a download for a user"并避免多个相同的服务器调用

javascript - Q promise 传播错误和异常

css - Node-SASS 编译器失败 - CSS 无效

javascript - 跨域问题,不同端口的HTTP请求

angularjs - 避免在 AngularJS 中使用 $resource 发送选项(预检)的最佳方法是什么

ios - 如何检查iPhone应用程序的网络事件?

node.js/ express : Sending static files if they exist