Skip to content

リアルタイム通信メカニズム(Polling / SSE / WebSocket)

核心ガイド

ブラウザはどのようにデータのリアルタイム更新を実現しているのか? 従来の HTTP プロトコルは「リクエスト-レスポンス」モデルに基づいており、クライアントが能動的にリクエストを発行しなければ、サーバーはデータを返すことができません。チャットルームや株式相場のプッシュ通知など、リアルタイムなシナリオを実現する必要がある場合、このモデルは大きな課題に直面します。

この章では、フロントエンドがリアルタイムデータ通信に対処するための3つの主要な技術——ショートポーリング(Polling)、サーバー送信イベント(SSE)、フルデュプレックス WebSocket——を紹介し、それぞれの原理と適用シナリオについて解説します。


1. 従来の HTTP の限界

HTTP プロトコルは元々ドキュメント検索のために設計されており、ステートレス(Stateless)クライアントからの一方向の開始という特徴を持っています:

  1. クライアントが HTTP リクエストを発行する。
  2. サーバーがリクエストを処理し、レスポンスを返す。
  3. タスク完了後、通常は対応する論理リクエストが解放される(HTTP/1.1 は永続的接続の再利用をサポートしていますが、ビジネスレベルでのリクエスト-レスポンスモデルは変わっていません)。

このモデルでは、サーバーは待機中のクライアントに状態の変化を随時通知することができません。最新のデータを取得するには、他の技術的アーキテクチャソリューションを探す必要があります。


2. ショートポーリング(Polling)

最も直接的なソリューションはショートポーリングです。クライアントがタイマー(setInterval など)を使用して、一定間隔で自動的にサーバーに HTTP リクエストを送信し、新しいデータが到着しているかどうかを確認します。

技術的特徴と限界:

  • 利点:実装メカニズムが極めてシンプルで、標準的な HTTP プロトコルと AJAX/Fetch 技術に完全に依存しています。
  • 欠点:多大なネットワークオーバーヘッドとリソースの浪費を生じる可能性があります。ほとんどの時間、サーバーのレスポンスは「新規データなし」かもしれません。データの有無にかかわらず、各リクエストには完全な HTTP ヘッダー(Headers、Cookies など)を含める必要があり、同時接続数が多いシナリオでは、ネットワークリソースが大量の無意味なクエリに占有されることになります。

3. サーバー送信イベント(Server-Sent Events)

HTTP 接続を頻繁に確立するオーバーヘッドを減らすため、Server-Sent Events (SSE) は軽量な一方向データストリームプッシュアーキテクチャを提供します。

SSE は HTTP プロトコル上に構築されています。クライアントが特殊なリクエストヘッダー(Accept: text/event-stream)を含む HTTP リクエストを発行すると、サーバーはレスポンスを返す際に基盤となる TCP 接続を切断せずに維持します。その後、サーバーはこの永続的なチャネルを通じて、テキスト形式のデータを継続的にクライアントにプッシュすることができます。

技術的特徴と限界:

  • 利点:接続の永続化によりネットワークオーバーヘッドが小さい;ブラウザがネイティブで切断時の自動再接続メカニズムをサポート;サーバーからクライアントへの一方向のストリーミングデータ転送(例:大規模言語モデルのテキストのトークンごとの出力、リアルタイム取引用フィードのプッシュ)に非常に適している。
  • 欠点:通信チャネルは一方向である。クライアントからサーバーに制御コマンドや新しいデータを送信する必要がある場合、別途通常の HTTP リクエストを確立する必要がある。

4. WebSocket:フルデュプレックス通信プロトコル

アプリケーションのシナリオが高頻度の双方向インタラクション(マルチプレイヤーオンラインアクションゲーム、精密な協調ドキュメント編集など)を伴う場合、通信オーバーヘッドを削減しつつ真のデュプレックス通信を実現する技術が必要になります——それが WebSocket です。

WebSocket は独立したネットワーク通信プロトコルです。HTTP プロトコルを巧みに利用して初期接続を完了します:

  1. ハンドシェイクフェーズ:クライアントが特殊な HTTP リクエストを送信し、新しいプロトコルへのアップグレードを希望することを宣言する(Upgrade: websocket ヘッダーを含む)。
  2. 接続の変質:サーバーがプロトコルをサポートし、同意する場合、101 Switching Protocols ステータスコードで応答する。
  3. 完全な自由:この時点で HTTP の仕様としての役割は終了し、基盤となる TCP 接続が WebSocket プロトコルに引き渡される。以降、クライアントとサーバーは対等なフルデュプレックス(Full-Duplex)通信権を持ち、双方はいつでも最小フォーマットのデータフレームを送受信できる。

技術的特徴と限界:

  • 利点:真の双方向リアルタイム通信をサポート;データフレームのヘッダー情報が極めて小さく、通信遅延が低くスループット効率が高い;ネイティブのバイナリデータ(ArrayBuffer)の転送をサポート。
  • 欠点:アーキテクチャと開発の複雑性が高い;永続的な長接続を維持するため、サーバー側のシステムアーキテクチャ、負荷分散戦略、ハートビート監視設計に対してより厳しいエンジニアリング要件が求められる。

5. まとめ:技術選定の比較

側面ショートポーリング (Polling)サーバー送信イベント (SSE)WebSocket
通信方向クライアントが能動的にポーリングして取得(一方向)サーバーが継続的に能動的にプッシュ(一方向)クライアントとサーバーが対等な送受信権を持つ(双方向フルデュプレックス)
基盤プロトコル標準 HTTP標準 HTTP独立した WebSocket プロトコル(TCP ベース)
データオーバーヘッド極めて高い(完全な HTTP ヘッダーを含む)極めて低い(最小限のデータフレームヘッダー)
典型的なユースケースバックエンドの非同期タスクの完了状態の定期チェックLLM 対話の一方向ストリーム出力、ニュースやシステム通知のプッシュリアルタイム音声/映像シグナリング、マルチプレイヤーオンライン対戦、協調ホワイトボードと編集

実際のエンジニアリングでは、開発者は具体的なビジネスシナリオのリアルタイム性と双方向インタラクションの頻度に対する要件に基づき、システムの保守複雑性と通信効率のバランスを取りながら、最も適合する技術スタックを選択すべきです。