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);
...
}
答案 0 :(得分:0)