From 4f467abf1ee9341630c18768e37b8b9799927fcb Mon Sep 17 00:00:00 2001 From: HugoPoi Date: Fri, 17 Jan 2020 15:12:00 +0100 Subject: [PATCH] fix(scrape-manager): keywords propagated through a clone config for not being re-affected --- src/modules/se_scraper.js | 4 +++- src/node_scraper.js | 22 ++++++---------------- 2 files changed, 9 insertions(+), 17 deletions(-) diff --git a/src/modules/se_scraper.js b/src/modules/se_scraper.js index 7fe9e71..95e0c16 100644 --- a/src/modules/se_scraper.js +++ b/src/modules/se_scraper.js @@ -50,7 +50,9 @@ module.exports = class Scraper { } } - async run({page, data}) { + async run({page, data, worker}) { + + debug('worker.id=%s', worker.id, this.config.keywords); if (page) { this.page = page; diff --git a/src/node_scraper.js b/src/node_scraper.js index 0b87c09..ed9564e 100644 --- a/src/node_scraper.js +++ b/src/node_scraper.js @@ -281,11 +281,6 @@ class ScrapeManager { perBrowserOptions: perBrowserOptions } }); - - this.cluster.on('taskerror', (err, data) => { - this.logger.error(`Error while scraping ${data}: ${err.message}`); - debug('Error during cluster task', err); - }); } } @@ -336,26 +331,21 @@ class ScrapeManager { chunks[k % this.numClusters].push(this.config.keywords[k]); } - let execPromises = []; - let scraperInstances = []; - for (var c = 0; c < chunks.length; c++) { - this.config.keywords = chunks[c]; + debug('chunks=%o', chunks); - if (this.config.use_proxies_only) { - this.config.proxy = this.config.proxies[c]; // every cluster has a dedicated proxy - } else if(c > 0) { - this.config.proxy = this.config.proxies[c-1]; // first cluster uses own ip address - } + let execPromises = []; + for (var c = 0; c < chunks.length; c++) { + const config = _.clone(this.config); + config.keywords = chunks[c]; var obj = getScraper(this.config.search_engine, { - config: this.config, + config: config, context: {}, pluggable: this.pluggable, }); var boundMethod = obj.run.bind(obj); execPromises.push(this.cluster.execute({}, boundMethod)); - scraperInstances.push(obj); } let promiseReturns = await Promise.all(execPromises);