この記事の内容
Webアプリ開発の基礎を学んだばかりの初心者エンジニアです。
最近、WebRTCについて調査する機会があったので、整理を兼ねてWebRTCの仕組みをまとめてみました。
自分と同じような初心者エンジニアの方のお役に立てれば幸いです。
WebRTCって何?
WebRTC(Web Real-Time Communication)とは、ブラウザ間でリアルタイムにデータをやり取りする仕組みのこと。web会議アプリなどに利用されている仕組みです。
WebRTCの特徴
Webアプリというと、クライアントとサーバー間のリクエスト・レスポンス型の通信を思い浮かべます。しかし、WebRTCの場合は、サーバーを介さず、ブラウザ同士が直接データを送受信するP2P※1で通信しています。これがWebRTCの最大の特徴です。
※1.P2P(Peer to Peer)とは、複数の端末同士がサーバーを介さずに直接通信する技術。
WebRTCの基本的な仕組み
ステップ1.P2P通信の準備
ブラウザ間でP2P通信するには、あらかじめ、通信相手のIPアドレス等を知る必要があります。そのために、まずシグナリングサーバー※2を経由して、SDP※3を相手のブラウザと交換します。
※2.シグナリングサーバーとは、P2P通信を開始する前に、必要な情報を相手のブラウザと交換するための仲介役のサーバー。
※3.SDP(Session Description Protocol)は、通信に必要な情報(IPアドレス、ポート番号、暗号化通信のめの公開鍵情報、メディアの形式、通信帯域など)のプロトコル。
ステップ2.P2P通信開始
SDPを共有すると、候補の通信経路を試行して、P2P通信を確立します。この通信には、リアルタイム性を求める通信に適したUDP※4を利用します。
これで、ブラウザ同士がオーディオ/ビデオなどのデータを送受信するWeb会議が成立します。送信するデータは、ビデオ/オーディオを送信するのに適したSRTP、または様々なデータ形式に対応したSCTPで暗号化されています。
※4.UDPとは、トランスポート層のプロトコル。データの誤りや順序の違いなどを検出する機能がないので、TCPと比べて遅延が発生しにくい。
NAT越えの課題
WebRTCの基本的な仕組みは上記です。しかし、実際にはNAT※5が存在するため、簡単にP2P通信は成立しません。NAT配下のPCに、NATの外側から直接データを送信することはできないからです。WebRTCでは、STUNサーバー、TURNサーバーを利用して課題を解決しています。
※5.NAT(Network Address Translation)とは、プライベートIPアドレスをグローバルIPアドレスに変換、またその逆の変換を行う仕組みのこと。
STUNサーバーの役割
前述の通り、P2P通信の準備として、ブラウザはSDPを送信して自身のグローバルIPアドレスを相手に伝えなくてはなりません。しかし、NAT配下のブラウザは自分のグローバルIPアドレスを知りません。そこで、STUNサーバー※6にアクセスして自分のグローバルIPアドレスを取得し、相手にSDPを送信します。
※6.STUNサーバーとは、NAT配下にあるPCがNATの外側から見たグローバルIPアドレスを知るためのもの。この、NAT配下のPCと通信できるようにする仕組みのことをNAT越えと言います。
TURNサーバーの役割
STUNサーバーでIPアドレスを確認出来ても、セキュリティ性の高いNATの場合はP2P通信を確立できないことがあります。そんな場合に利用するのがTURNサーバー※7です。P2P通信時に、TURNサーバーが仲介することでNATを超えたデータの送受信を可能にします。
※7.TURNサーバーとは、PC同士の間に立って、データの中継をしてくれるサーバー。このサーバーでデータの変形は行われません。
以上のように、P2P通信を確立させる際には、ブラウザ間の直接通信を試し、必要に応じてSTUNサーバーへアクセスし、それでも通信が確立しない場合はTURNサーバーを利用します。このような通信経路を見つけ出す仕組みを、ICE(Interactive Connectivity Establishment)と言います。WebRTCでは、SDPにICE Candidateという通信経路候補を含めて、相手に経路情報を伝えています。
まとめ
- WebRTCとは、ブラウザ間のP2P通信でデータをやり取りする仕組みのこと。
- P2P通信を成立するにはシグナリングサーバーが必要。
- 必要に応じて、STUNサーバー、TURNサーバーを利用して通信する。
以上、初心者エンジニアがWebRTCの仕組みをまとめてみました。
不適切な表現がございましたら、ご指摘頂けますと幸いです。
次回はハンズオンとして、Amazon Kinesis Video Streams WebRTCを使ってWebチャットアプリの実装をします。
参考サイト
以下のサイトを参考にさせて頂きました。
- [WebRTC入門2016]
(https://html5experts.jp/series/webrtc2016/) - [WebRTCの基本とP2P通信が成立するまでを学ぶ]
(https://qiita.com/daitasu/items/ae21b16361eb9f65ed43) - 【初心者向け】STUN/TURNサーバをざっくり解説してみた
- WebRTCにおけるNAT越えの課題へのアプローチ