Я написал скрипт в Nodejs, который делает скриншот веб-сайтов (используя slimerJs
), этот скрипт занимает около 10-20 секунд, проблема здесь в том, что сервер останавливается, пока этот скрипт не будет завершен.
app.get('/screenshot', function (req, res, next) {
var url = req.query.url;
assert(url, "query param 'url' needed");
// actual saving happens here
var fileName = URL.parse(url).hostname + '_' + Date.now() + '.png';
var command = 'xvfb-run -a -n 5 node slimerScript.js '+ url + ' '+ fileName;
exec(command, function (err, stdout, stderror) {
if(err){ return next(err); }
if(stderror && (stderror.indexOf('error')!= -1) ){ return next(new Error('Error occurred!')); }
return res.send({
status: true,
data: {
fileName: fileName,
url: "http://"+path.join(req.headers.host,'screenshots', fileName)
}
});
})
});
Поскольку скрипт запускает браузер Firefox в памяти и загружает веб-сайт, использование оперативной памяти может достигать 600-700 МБ, и поэтому я не могу выполнять эту команду асинхронно, поскольку оперативная память на серверах дорогая.
могу ли я узнать, возможно ли ставить в очередь входящие запросы и выполнять их в порядке FIFO?
я пробовал проверять такие пакеты, как kue, bull и bee-queues, но я думаю, что все они предполагают, что список заданий уже известен до запуска очереди, где мой список заданий зависит от пользователей, использующих сайт, и я также хочу сообщить людям, что они стоят в очереди и должны ждать своей очереди. это возможно с вышеупомянутыми пакетами?