質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
スクレイピング

スクレイピングとは、公開されているWebサイトからページ内の情報を抽出する技術です。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

Q&A

1回答

2859閲覧

puppeteerでMaxListeners()の上限を増やす方法が知りたい

退会済みユーザー

退会済みユーザー

総合スコア0

スクレイピング

スクレイピングとは、公開されているWebサイトからページ内の情報を抽出する技術です。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

0グッド

0クリップ

投稿2018/04/25 03:44

編集2022/01/12 10:55

よろしくお願いします。

イベントハンドラの数を変更すればいいと思ったのですが、
なにも変化がなかったので解決策が知りたいです。

以下コードです。

typescript

1// main.ts 2import * as test from ""../test; 3(async () => { 4 const events = require('events'); 5 const eventEmitter = new events.EventEmitter(); 6 eventEmitter.setMaxListeners(0);  7 8 for(let i=0; i<11; i++) { 9 let result = await funcRun(); 10 console.log(i); 11 } 12 13 function funcRun(p: string) { 14 return test.testFunc(); 15 } 16})

typescript

1// pup.ts 2const assert = require('assert'); 3const puppeteer = require('puppeteer'); 4 5export async function testFunc(){ 6 process.on('unhandledRejection', console.dir); 7 const browser = await puppeteer.launch(); 8 const page = await browser.newPage(); 9 10 await page.goto('http://~~', {waitUntil: 'networkidle2'}); 11 12 await page.focus('input[name="username"]'); 13 await page.type('xxxxx'); 14 await page.focus('input[name="password"]'); 15 await page.type('yyyyy'); 16 const buttonElement = await page.$('button[type=submit]'); 17 await buttonElement.click(); 18 await page.waitFor(5000); 19 20 const selecterResult = await page.evaluate(() => { 21 const node = document.body.querySelector('span'); 22 return node.tagName; 23 }); 24 25 await browser.close(); 26 return 'end'; 27}

実行結果は以下です。

end

end
end
end
end
end
end
end
end
MaxListenersExceededWarning: Possible EventEmitter memory leak detected. 11 unhandledRejection listeners added. Use emitter.setMaxListeners() to increase limit
end
end

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

HayatoKamono

2018/04/27 14:50 編集

※修正依頼を行いましたが削除しました。(やり取りが長引きそうなのと、責任を持った継続的な対応ができないため、既に投稿済みの回答を持って一旦引かせて頂きます。)
guest

回答1

0

EventEmitter memory leak detected. 11 exit listeners added #594

こちらが参考になるかと思います。

投稿2018/04/25 03:55

HayatoKamono

総合スコア2415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/04/26 12:29

大変参考になる記事をありがとうございます。 一通り調べた中にその記事もあったので見てはいたのですが、解決することはできませんでした。 現状の問題を解決するにはどのようにコードを書くのか、ぜひ教えていただきたいです。
退会済みユーザー

退会済みユーザー

2018/04/27 11:59

返信ありがとうございます。 追記しましたのでご覧ください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問