Javascript 如何修复错误:产卵迷恋木偶师?

Javascript 如何修复错误:产卵迷恋木偶师?,javascript,node.js,puppeteer,Javascript,Node.js,Puppeteer,我想使用Puppeter解析来自电子商务网站的新产品信息。当我在1-2小时后运行我的代码时,取决于我运行的浏览器数量(如果我在+-1小时后运行2个浏览器),会发生一个错误,并且Puppeter浏览器不会生成unitll。我将重新启动代码执行 错误:生成Enametolong Error: spawn ENAMETOOLONG at ChildProcess.spawn (internal/child_process.js:407:11) at Object.spawn (

我想使用Puppeter解析来自电子商务网站的新产品信息。当我在1-2小时后运行我的代码时,取决于我运行的浏览器数量(如果我在+-1小时后运行2个浏览器),会发生一个错误,并且Puppeter浏览器不会生成unitll。我将重新启动代码执行

错误:生成Enametolong

Error: spawn ENAMETOOLONG
      at ChildProcess.spawn (internal/child_process.js:407:11)
      at Object.spawn (child_process.js:553:9)
      at BrowserRunner.start (C:\Users\Administrator\Desktop\crawler-test\node_modules\puppeteer\lib\launcher\BrowserRunner.js:51:34)
      at ChromeLauncher.launch (C:\Users\Administrator\Desktop\crawler-test\node_modules\puppeteer\lib\Launcher.js:64:16)
      at async PuppeteerExtra.launch (C:\Users\Administrator\Desktop\crawler-test\node_modules\puppeteer-extra\dist\index.cjs.js:129:25)
      at async getDataRestock (C:\Users\Administrator\Desktop\crawler-test\test.js:122:21) {  
errno: 'ENAMETOOLONG',   
code: 'ENAMETOOLONG',  
syscall: 'spawn' }
下面是一个示例代码:

  • 木偶演员版本:v3.3.0
  • 平台/操作系统版本:win64
  • Node.js版本:v14

我知道警告很糟糕,但我认为这与错误无关。非常感谢您的帮助和想法。

您找到了解决方法吗?@AlexandruCancescu没有,我只是停止了频繁关闭浏览器并启动重新启动页面,或者您可以使用browser.process().kill(“SIGKILL”)。但我认为如果没有你的控制,你的应用程序将无法运行数天
const puppeteer = require('puppeteer-extra');
const pluginProxy = require('puppeteer-extra-plugin-proxy');

async function getData(urlNew, ...args, proxy) {
    puppeteer.use(pluginProxy({
        address: proxy,
        port: 1050,
        credentials: {
            username: 'okQLjn',
            password: 'vYTNDiJ24D',
        }
    }));
    const browser = await puppeteer.launch({  args: ['--disable-dev-shm-usage'], headless: false });
    const page = await browser.newPage();
    await page.setCookie(...cookies)
    try {
        await page.goto(urlNew, {
            waitUntil: 'networkidle0',
        });
        const data = await page.evaluate(({ ...args }) => {
           //do some parsing
            return prodsAndSizesAndHookProducts;
        }, { ...args });
        await page.close();
        await browser.close();
        return data;
    } catch (err) {
        console.log("ERROR new " + err + ' proxy: ' + proxy);
        await page.close();
        await browser.close();
        Parser(...args)
    }
}

function Parser(...args) {
    if (proxiesTempArr.length == 0) {
        proxiesTempArr.push(...proxies);
    }
    const proxy = proxiesTempArr.shift();
    getData(url, ...args, proxy)
        .then(result => {
            if (result != undefined) {
                const status = 'new product'
                for (let i = 0; i < result[1].length; i++) {
                    Discord.sendHook(...args);
                    Slack.sendHook(...args);
                }
                console.log(status)
                Parser(...args);
            }
        })
        .catch(err => {
            console.log(err + ' err new '  + new Date().toLocaleString());
            Parser(...args);
        })
}

Parser(...args)
MaxListenersExceededWarning: Possible EventEmitter memory leak detected. 11 targetcreated listeners added to [Browser]. Use emitter.setMaxListeners() to increase limit  
ERROR: The process with PID 1244 (child process of PID 7208) could not be terminated.  
Reason: There is no running instance of the task.