私はNode.jsの観点から、IOバインドされたユースケースのために一般的なコンセンサスが輝いているように見えます。私は次のFacebook/Twitterを構築しようとはしていないが、私の質問はソーシャルネットワーキングサイトが一般的にI/OバウンドかCPUバウンドですか?ソーシャルネットワーキングはこのような多種多様なコンテキストを網羅することができるので、チャット、インスタントメッセージング、ユーザ追跡、ステータス更新などの機能に特に関心があることをさらに述べる。これらのタイプのものについては、ボトルネックは一般的にCPUまたはIO側で発生しますか?FacebookやTwitterのCPUやIOなどのソーシャルサイトはバインドされていますか?
-1
A
答えて
3
私は毎月20万人の月間アクティブユーザーのサイトの主任エンジニアでした。私たちは間違いなくI/Oに縛られていました。
スケーリングCPUは非常に簡単です。新しいノードをネットワーク上で起動し、ロードバランサの利用可能なプールに追加します。一方、スケーリングI/Oは、データがアドレス可能性と妥当な一貫性を維持しなければならないため、非常に扱いにくく高価です。
読み取り側では、レプリケーションをサポートすることで拡張できます。これには、レプリケーションの遅延を許容できるソフトウェアの作成が必要です。データが書き込みDBから読み取りDBに移動するのにかかる時間です。私たちは1つの書き込みサーバーに対して4つの読み取りサーバーを持っていました。高負荷の場合、遅延は秒になります。我々は、キャッシュがmemcachedを介して電源供給され、ハイラムサーバのクラスタが使用される、ライトバックキャッシュを使用したI/Oアクセスを実装することを選択しました。
書き込み側では、同時書き込みの数を維持するためにデータシャーディングが必要です。つまり、テーブル結合を使用することはできず、断片全体のアトミック性が失われます。繰り返しますが、ソフトウェアはこれに耐えなければなりません。
また、フォトピクチャのようなバイナリデータを扱う場合、サイトは通常、より良いファイルシステムI/Oのために最適化されたCDNを使用します。
私の主なポイントは、典型的なソーシャルネットワーキングサイトでは、I/OとCPUのスケーリングに費やされる時間とコストが大幅に増えたことです。
関連する問題
- 1. は、FacebookやTwitter
- 2. どうやってFacebookやTwitterでログインできますか?
- 3. FacebookやTwitterなどの通知セクション
- 4. アンドロイド:ロードFacebookなどのデータやTwitter
- 5. トリガ@mention FacebookやTwitterなどのオートコンプリートやGoogle+
- 6. iOS 6でTwitterアカウントやFacebookアカウントが設定されていない場合はどうなりますか?
- 7. Facebook、twitter linkedin、youtube、vimeoなどのソーシャルサイトにコンテンツを配信
- 8. PHP Facebookやtwitterのようなニュースフィード
- 9. Twitterの統合やSpringソーシャルを使ってTwitterやFacebookと対話する必要はありますか?
- 10. 必要... TwitterやFacebook、カウンター
- 11. はのWhatsAppやFacebookなど
- 12. FacebookやTwitterへのWordpress投稿
- 13. インストールされているRAMやCPUなどのシステム仕様のMySQLクエリ
- 14. FacebookでFacebookやTwitterは、Google +、およびLinkedInの
- 15. FacebookやTwitterなどの画像ビューアを作成するには? iOS
- 16. jQuery:FacebookやTwitterなどの固定トップメニュー
- 17. FacebookやTwitterでハイスコアを共有
- 18. FacebookやTwitterのようにフィードのユーザーにタグを付けるにはどうすればいいですか?
- 19. jQueryアコーディオンプラグイン(FacebookやGoogleなど)
- 20. TwitterやFacebook用のDisqusのようなログインシステム
- 21. ユーザー名でFacebookやTwitterのアバターへのリンクを取得するにはどうすればよいですか?
- 22. TwitterやFacebookの投稿をオーチャードのブログに集めるには?
- 23. facebookやtwitterのような更新後の時間を表示するには?
- 24. TwitterやROAuth
- 25. 「@」付きのAndroid AutoCompleteTextViewはtwitterやfacebookのようなフィルタリングを言及しています
- 26. FacebookのJavascript APIのコールバックに何が渡されたのか、どうやって知っていますか?
- 27. Facebookページのaboutセクションをどうやって削りますか?
- 28. TwitterやFacebookに招待友人を実装する方法は?
- 29. Twitter Twitterでつぶやく
- 30. PHPでのカウンターとのWhatsAppのFacebookやTwitter