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/