【node.js】サーバサイドjavascript 5【Nashorn】 (796レス)
上下前次1-新
538: 2020/09/09(水)06:42 ID:N3PFvdWI(1) AAS
スレ的には真っ当な質問なのに当たり強過ぎでしょ
539: 2020/09/09(水)08:44 ID:7Dxn++Hv(1) AAS
質問じゃなくて文句
540: 2020/09/09(水)17:07 ID:SFlZHAWP(1) AAS
謙虚に質問してればレスも優しかったかもよ
541: 2020/09/09(水)21:03 ID:OFM+73CL(1) AAS
分からないだけならともかく延々と自分以外を貶めつつ無能を晒してたからなぁ
542: 2020/09/09(水)21:12 ID:XGuez22g(1) AAS
それな
× node.js が悪い
× 非同期が悪い
× promise が悪い
× async/awaitが悪い
× 新人がバカ
○ ID:8muSUg7S がバカ
こうだからな
543: 2020/09/10(木)14:55 ID:rLZBXCmM(1) AAS
グレたωωω
544(1): 2020/09/10(木)19:56 ID:FWP0gZB+(1) AAS
clusterでマルチプロセスしようとしたんだけど
「EADDRINUSE(ポートが既に使われている)」
エラーがどうしても出てしまいます。
もちろん既に稼働しているnodeはなく、
fork元のapp.jsでlistenしているのと同じポート
子プロセスでまたbindしようとして失敗しているようで
子プロセスは外部からリクエストを受けるような
ものではなく、重い処理をコア分散させて並列処理したいだけです
子プロセスにポート割り当てが必要な理由がよく分かりませんが
恐らく親プロセスと子プロセス間の通信
とかに使うんでしょうか?
子プロセスのポート割り当て回避か、
親プロセスと別ポートを割り当てる方法はありますか?
545(1): 2020/09/10(木)20:18 ID:VafdMbGz(1) AAS
> 子プロセスは外部からリクエストを受けるようなものではなく
それならclusterモジュールは必要なくね
clustetは複数のプロセスを使って大量のリクエストを捌くためのもの
ただの子プロセスならchild_processのメソッドを使う
546: 2020/09/10(木)20:21 ID:C+K2oJgr(1) AAS
>>545
なるほど、助かりました
じつはworker_threadsも試してみて同じ
エラー出たので
child_processが正解でしたか
これだとポートは関係ない?
547: 2020/09/10(木)20:43 ID:oBZEl9rg(1/2) AAS
clusterだと親は子を産むだけの役割じゃなかったっけ
548: 2020/09/10(木)20:45 ID:oBZEl9rg(2/2) AAS
あとworker_threadsで同じエラーが出るのはいくらなんでもおかしい
549: 2020/09/14(月)20:42 ID:JdQogpR1(1/4) AAS
>>544 の者ですが
今日これをデバッグしてました。
clusterでもwoker_threadsfでも
child_processでも
「EADDRINUSE」が発生しました
発生するタイミングは子プロセスを生成した時でも
なく
子プロセスでMySQLに対しのコネクション確立時でもなく
確立したDBコネクションからクエリを投げるコード
を実行する時に発生しますが
なぜこのタイミングなのか分かりません
ここで気になったのが
nodeでフロントユーザーに対し
80番ポートをlistenしていて
nodeがローカルのMySQLにアクセスする時
nodeのクライアントポートはフロントと
おなじ80を使うのでしょうか?
それとも別のランダムポートを取得してきて使うのでしょうか?
550(1): 2020/09/14(月)20:55 ID:AayaioGL(1/2) AAS
説明と全然違う事象じゃねーの
せめてエラーメッセージとスタックトレース貼れ
551: 2020/09/14(月)20:55 ID:JdQogpR1(2/4) AAS
続きですか
もう少し調べてみると
「EADDRINUSE」が発生するタイミングは
MySQLに対しコネクション確立後
SQLを投げる時で間違いないと思いますが、
エラーのスタックとレースを見ても
何かのハンドラから駆動されており自分の書いたコードでは
ありません。
nodeかexpressかmysqlモジュールのハンドラ
だと思います
子プロセスはローカルのMySQLに対して
接続して読み書きするだけで
フロントとのやり取りは一切ありませんが
生成元の親プロセスはExpressのapp.js
で立ち上げてるwebアプリです
552: 2020/09/14(月)20:56 ID:JdQogpR1(3/4) AAS
不思議なのが子プロセスで
mysqlとコネクション確立までは失敗せずに
動作し、SQLを投げる段階で
なぜか大元の「app.js」をもう1つ起動しようとしており
app.jsはもう既に起動してるので、
listenポート重複により上記のエラーが発生するわけです
暫定対応で動くようにはなりましたが、
なぜローカルのDBアクセス時にapp.js実行する
動きをするのかの原因がまだ分かっていません
webとは関係ないはずの子プロセスのファイルを
単体でコマンドで実行した場合も
Expressのベースディレクトリにある
「app.js」が実行されていることが分かりました。
自身のコードではこのようなことをしてないので
フレームワークかモジュールの内部処理だと思いますが、
知っている方がいましたら教えてください。
553: 2020/09/14(月)20:57 ID:JdQogpR1(4/4) AAS
>>550
すみません、もう帰宅してしまったのと
機密事項で怒られるのでスタックトレースは貼れません
554: 2020/09/14(月)21:14 ID:AayaioGL(2/2) AAS
> 単体でコマンドで実行した場合も
> Expressのベースディレクトリにある
> 「app.js」が実行されていることが分かりました。
clusterも何も関係ねーじゃんwww
断言するがフレームワークもモジュールもmysqlも関係なくてお前のバグだから真面目に仕事しろ
子プロセスから再現に関係ない部分を削除しまくって最小限のここで見せられるコードになるまで書き込まなくていいよ
555: 2020/10/03(土)14:17 ID:l4QjehZB(1) AAS
https://detail.chiebukuro.yahoo.co.jp/qa/question_detail/q14232251614?sort=1&page=2
abiko tetuってやつヤバすぎ
556(1): 2020/10/17(土)18:10 ID:cX3MrjsP(1/2) AAS
フォルダ全体をコピーしたくて fs-extra のcopySync()を使うために
const fse = require('fs-extra');
としたら、
internal/modules/cjs/loader.js:968
throw err;
^
Error: Cannot find module 'fs-extra'
というエラーが出ます。
npm install fs-extra
や
npm install -g fs-extra
を試しましたが、途中で警告が出たりして、結局、元のエラーは直りません。
直す方法はありますでしょうか?
557: 2020/10/17(土)18:39 ID:cX3MrjsP(2/2) AAS
>>556
結論的には、
$ npm install -g fs-extra
$ set NODE_PATH=%AppData%\npm\node_modules
としてから、
node xxxx.js
とすると直りました。
上下前次1-新書関写板覧索設栞歴
あと 239 レスあります
スレ情報 赤レス抽出 画像レス抽出 歴の未読スレ AAサムネイル
ぬこの手 ぬこTOP 0.016s