-
-
Notifications
You must be signed in to change notification settings - Fork 139
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
MaxListenersExceededWarning when trying to resolve more than 10 URLs #42
Comments
I've been fighting with this also -- you can run more than 10 by adding this to the top of your code:
to override the default number of listeners, but the problem here is that Node is warning you of possible memory leaks, which actually comes true depending on your server power. In my case, I'm trying to spin through a list of 50 sites, which almost always crashes my $5/mo Digital Ocean droplet. (On my local machine it will run.) Not sure how much server power it will require to run through a list this big and I don't want to pay more, so for now I'm attempting to chunk my array of sites into lists of 10 (which runs fine on d.o), followed by a long setTimeout but so far no luck due to a different set of errors that seem to be related to trying to use different Chrome ids. That said I've tried a bunch of similar libraries and this one seems the best, and i think the limitations may ultimately come down to puppeter/headless Chrome and the need for a lot of resources on large lists. I'm not familiar enough with the code myself to know if anything could be done inside capture-website to improve performance on bigger lists. |
This might not be ideal but after messing around with numerous other approaches, I finally found a very simple solution that will allow me to spin through 50 sites (and presumably more) on a cheap server:
It seems for me the key is to wait 10 seconds between captures to give my server some breathing room. Three seconds was not long enough, I may be able to go lower but 10 seconds and it seems to chug right along with no error. Note that this code does NOT need the unlimited listeners code i posted above, see here for a good discussion and particularly this comment: https://stackoverflow.com/a/44446859/11777731 YMMV and if you have stronger server you may not need this but after a few days I can finally set a nightly cron with more than a few sites :) |
Thanks for comprehensive answer. I've ended up with the usage of puppeteer itself and making screenshot using the same instance. In the loop I'm taking a screenshot, reload chrome to another URL, taking a screenshot, reload chrome and so on.
|
I found some workarounds we could try to add to |
As a workaround one can limit the concurrency of the promises by wrapping them with a limiter function like one provided by Your code will look something like this: const pLimit = require('p-limit');
const urlsArray = []; // more than 10 items
let imagePromises = [];
const limit = pLimit(4);
urlsArray.forEach(item => {
const imagePath = `./tmp/${item.id}.jpg`;
const captureWebsitePromise = captureWebsite.file(item.url, imagePath, {
width: 1280,
height: 800,
type: 'jpeg',
overwrite: true
});
imagePromises.push(limit(captureWebsitePromise));
});
Promise.all(imagePromises).then(function (imageResult) {}); |
Even easier to use |
When I invoke code:
I have these errors:
Do you have an idea how to capture more than 10 pages using your module?
The text was updated successfully, but these errors were encountered: