チャットアプリケーションの開発にはsocket.ioとnode.jsを使用する方法がありますが、ノードの利点としてはチャットアプリケーションの利点があります。しかし、最近この考えが私の心に浮かんだ。私はアプリを配備するときにチャットアプリをどのように維持できるのだろうか?何千人ものユーザーが積極的にチャットしていると想像してください。node.jsアプリケーションのデプロイ時にpm2を使用してダウンタイム
この記事のhttps://futurestud.io/tutorials/pm2-cluster-mode-and-zero-downtime-restartsは、このクラスタのテクニカルには特別な注意が必要ですが、この問題に取り組む方法はありますか?
再起動に約数秒かかる。私はチャットアプリをテストしました。それはいつものように働いた。私はスプリット秒のためのダウンタイムを持っていると思うが、以前の確立ソケットは崩壊していない。 –
セッションのためのredisとsocket.io? socket.ioを使用してセッションが必要ですか? –
正しいですが、PM2自体を更新する必要がある場合は、ダウンタイムがそれよりも長くなります。 NodeJS itselを更新する必要がある場合は、それも同じです。なんらかの理由でマシンをリブートする必要がある場合は、クラスタ化されたすべてのインスタンスが失われます。だから私はPM2がこれのための最善のツールではないと(そしてダウンボートを得た)と言いました。これは素晴らしいスタートですが、「何千ものユーザー」がそれに頼っていると言いました。私は、これまで多くのユーザーがいるプロジェクトでPM2を使用することは決してありませんでした。イベントがノードインスタンスのクラスタを実行している場合でも、完全な停止時間から離れた単一の障害ポイントです。 –