SIP-クイックガイド
セッション開始プロトコル(SIP)は、VoIPテクノロジで使用される最も一般的なプロトコルの1つです。これは、他のアプリケーション層プロトコルと連携して機能し、インターネットを介したマルチメディア通信セッションを制御するアプリケーション層プロトコルです。
VoIPテクノロジー
先に進む前に、まずVoIPに関するいくつかのポイントを理解しましょう。
VOIPは、音声およびマルチメディア(ビデオ、写真)コンテンツをインターネット経由で配信できるようにするテクノロジーです。これは、いつでもどこでもインターネットが利用できる状態で通信するための最も安価な方法の1つです。
VOIPのいくつかの利点は次のとおりです。
低価格
Portability
余分なケーブルはありません
Flexibility
ビデオ会議
VOIP通話の場合、必要なのはインターネットに接続できるコンピューター/ラップトップ/モバイルだけです。次の図は、VoIP通話がどのように行われるかを示しています。
これだけ基本的なことで、SIPに戻りましょう。
SIP –概要
以下に、SIPについて注意すべきいくつかのポイントを示します。
SIPは、インターネットプロトコルを介してマルチメディアセッションを作成、変更、および終了するために使用されるシグナリングプロトコルです。セッションは、2つのエンドポイント間の単純な呼び出しに他なりません。エンドポイントは、スマートフォン、ラップトップ、またはインターネットを介してマルチメディアコンテンツを送受信できる任意のデバイスです。
SIPは、IETF(Internet Engineering Task Force)標準で定義されているアプリケーション層プロトコルです。それはで定義されていますRFC 3261。
SIPは、クライアントサーバーアーキテクチャと、からのURLおよびURIの使用を具体化します。 HTTP およびからのテキストエンコーディングスキームとヘッダースタイル SMTP。
SIPは、IPネットワークを介して音声とビデオを配信するために使用されるセッションとRTP(リアルタイムトランスポートプロトコル)を記述するSDP(セッション記述プロトコル)の助けを借ります。
SIPは、2パーティ(ユニキャスト)またはマルチパーティ(マルチキャスト)セッションに使用できます。
その他のSIPアプリケーションには、ファイル転送、インスタントメッセージング、ビデオ会議、オンラインゲーム、およびスチームマルチメディア配信が含まれます。
SIPはどこに適合しますか?
基本的に、SIPはアプリケーション層プロトコルです。これは、1人以上の参加者とのセッションを作成および終了するための単純なネットワークシグナリングプロトコルです。SIPプロトコルは、基盤となるトランスポートプロトコルから独立するように設計されているため、SIPアプリケーションはTCP、UDP、またはその他の下位層のネットワークプロトコルで実行できます。
次の図は、SIPが一般的なスキームのどこに適合するかを示しています。
通常、SIPプロトコルは、2つ以上のエンドポイント間のインターネットテレフォニーおよびマルチメディア配信に使用されます。たとえば、ある人がSIPを使用して別の人に電話をかけたり、誰かが多くの参加者との電話会議を作成したりできます。
SIPプロトコルは、コマンドのセットが限られているため、非常にシンプルになるように設計されています。また、テキストベースであるため、SIPセッションでエンドポイント間で渡されるSIPメッセージを誰でも読み取ることができます。
SIPがネットワークを作成するのを支援するエンティティがいくつかあります。SIPでは、すべてのネットワーク要素は次のように識別されます。SIP URI(Uniform Resource Identifier)これはアドレスのようなものです。以下はネットワーク要素です-
- ユーザーエージェント
- プロキシサーバー
- レジストラサーバー
- リダイレクトサーバー
- ロケーションサーバー
ユーザーエージェント
これはエンドポイントであり、SIPネットワークの最も重要なネットワーク要素の1つです。エンドポイントは、セッションを開始、変更、または終了できます。ユーザーエージェントは、SIPネットワークの最もインテリジェントなデバイスまたはネットワーク要素です。それは、ソフトフォン、携帯電話、またはラップトップである可能性があります。
ユーザーエージェントは論理的に2つの部分に分けられます-
User Agent Client (UAC) −要求を送信し、応答を受信するエンティティ。
User Agent Server (UAS) −要求を受信して応答を送信するエンティティ。
SIPは、発信者の電話が通話を開始するクライアントとして機能し、着信者の電話が通話に応答するサーバーとして機能するクライアントサーバーアーキテクチャに基づいています。
プロキシサーバー
これは、ユーザーエージェントからの要求を受け取り、それを別のユーザーに転送するネットワーク要素です。
基本的に、プロキシサーバーの役割はルーターによく似ています。
SIPリクエストを理解し、URIを使用して先に送信するためのインテリジェンスがあります。
プロキシサーバーは、2つのユーザーエージェントの間にあります。
送信元と宛先の間に最大70のプロキシサーバーを配置できます。
プロキシサーバーには2つのタイプがあります-
Stateless Proxy Server−受信したメッセージを転送するだけです。このタイプのサーバーは、通話やトランザクションの情報を保存しません。
Stateful Proxy Server−このタイプのプロキシサーバーは、受信したすべての要求と応答を追跡し、必要に応じて将来使用できます。時間内に反対側からの応答がない場合は、要求を再送信できます。
レジストラサーバー
レジストラサーバーは、ユーザーエージェントからの登録要求を受け入れます。これは、ユーザーがネットワーク内で自分自身を認証するのに役立ちます。URIとユーザーの場所をデータベースに保存して、同じドメイン内の他のSIPサーバーを支援します。
SIP登録のプロセスを示す次の例を見てください。
ここで、呼び出し元はTMCドメインに登録したいと考えています。そのため、登録要求をTMCのレジストラサーバーに送信し、サーバーはクライアントを承認したときに200OK応答を返します。
リダイレクトサーバー
リダイレクトサーバーはリクエストを受信し、レジストラによって作成されたロケーションデータベースでリクエストの目的の受信者を検索します。
リダイレクトサーバーは、データベースを使用して位置情報を取得し、3xx(リダイレクト応答)でユーザーに応答します。このチュートリアルの後半で、応答コードについて説明します。
ロケーションサーバー
ロケーションサーバーは、発信者の可能なロケーションに関する情報をリダイレクトサーバーとプロキシサーバーに提供します。
ロケーションサーバーに接続できるのは、プロキシサーバーまたはリダイレクトサーバーのみです。
次の図は、セッションを確立する際に各ネットワーク要素が果たす役割を示しています。
SIP –システムアーキテクチャ
SIPは、階層化されたプロトコルとして構造化されています。つまり、SIPの動作は、各ステージ間の疎結合のみを伴う、かなり独立した一連の処理ステージの観点から説明されています。
SIPの最下層は syntax and encoding。そのエンコーディングは、拡張を使用して指定されますBackus-Naur Form grammar (BNF)。
2番目のレベルは transport layer。これは、クライアントが要求を送信して応答を受信する方法と、サーバーがネットワークを介して要求を受信して応答を送信する方法を定義します。すべてのSIP要素にはトランスポート層が含まれています。
次は transaction layer。トランザクションは、(トランスポート層を使用して)クライアントトランザクションからサーバートランザクションに送信される要求であり、サーバートランザクションからクライアントに返送されるその要求に対するすべての応答とともに行われます。ユーザーエージェントクライアント(UAC)が実行するタスクはすべて、一連のトランザクションを使用して実行されます。Stateless proxies トランザクションレイヤーは含まれません。
上のレイヤー transaction layerトランザクションユーザーと呼ばれます。を除く各SIPエンティティStateless proxies、はトランザクションユーザーです。
次の画像は、SIPセッションの基本的なコールフローを示しています。
以下に、上記のコールフローの段階的な説明を示します。
プロキシサーバーに送信されるINVITE要求は、セッションを開始する責任があります。
プロキシサーバーの送信 100 Trying 発信者(アリス)にすぐに応答して、INVITE要求の再送信を停止します。
プロキシサーバーは、ロケーションサーバーでボブのアドレスを検索します。アドレスを取得した後、INVITEリクエストをさらに転送します。
その後、 180 Ringing ボブによって生成された(暫定応答)はアリスに返されます。
A 200 OK ボブが電話を受け取った直後に応答が生成されます。
ボブは ACK アリスから、 200 OK。
同時に、セッションが確立され、RTPパケット(会話)が両端から流れ始めます。
会話後、参加者(アリスまたはボブ)は誰でも送信できます BYE セッションの終了を要求します。
BYE プロキシサーバーをバイパスして、アリスからボブに直接到達します。
最後に、ボブは 200 OK BYEを確認するための応答があり、セッションが終了します。
上記の基本的なコールフローでは、3つ transactions (1、2、3としてマークされている)利用可能です。
完全な呼び出し(INVITEから200 OKまで)は、 Dialog。
SIP台形
プロキシは、あるユーザーを別のユーザーに接続するのにどのように役立ちますか?次の図を参考にして調べてみましょう。
図に示されているトポロジは、SIP台形と呼ばれます。プロセスは次のように行われます-
発信者が通話を開始すると、INVITEメッセージがプロキシサーバーに送信されます。INVITEを受信すると、プロキシサーバーはDNSサーバーを使用して呼び出し先のアドレスを解決しようとします。
次のルートを取得した後、呼び出し元のプロキシサーバー(プロキシ1、アウトバウンドプロキシサーバーとも呼ばれます)は、呼び出し先のインバウンドプロキシサーバー(プロキシ2)として機能する呼び出し先のプロキシサーバーにINVITE要求を転送します。
インバウンドプロキシサーバーはロケーションサーバーに接続して、ユーザーが登録した呼び出し先のアドレスに関する情報を取得します。
ロケーションサーバーから情報を取得した後、ロケーションサーバーは通話を宛先に転送します。
ユーザーエージェントが自分のアドレスを知ると、通話をバイパスできます。つまり、会話は直接渡されます。
SIPメッセージには2つのタイプがあります- requests そして responses。
リクエストの開始行には、リクエストを定義するメソッドと、リクエストの送信先を定義するRequest-URIが含まれています。
同様に、応答の開始行には応答コードが含まれています。
リクエストメソッド
SIP requests通信を確立するために使用されるコードです。それらを補完するために、SIP responses これは通常、リクエストが成功したか失敗したかを示します。
方法として知られているこれらのSIP要求は、SIPメッセージを実行可能にします。
方法は、別のユーザーエージェントまたはサーバーによって実行される特定のアクションを要求するため、SIP要求と見なすことができます。
メソッドは2つのタイプに区別されます-
コアメソッド
拡張メソッド
コアメソッド
以下で説明するように、6つのコアメソッドがあります。
招待する
INVITEは、ユーザーエージェントとのセッションを開始するために使用されます。言い換えると、INVITEメソッドは、ユーザーエージェント間のメディアセッションを確立するために使用されます。
INVITEには、発信者のメディア情報をメッセージ本文に含めることができます。
INVITEが成功応答(2xx)を受信した場合、またはACKが送信された場合、セッションは確立されたと見なされます。
INVITEリクエストが成功すると、 dialog BYEが送信されてセッションが終了するまで続く2つのユーザーエージェント間。
確立されたダイアログ内で送信されるINVITEは、 re-INVITE。
Re-INVITEは、セッションの特性を変更したり、ダイアログの状態を更新したりするために使用されます。
INVITEの例
次のコードは、INVITEの使用方法を示しています。
INVITE sips:[email protected] SIP/2.0
Via: SIP/2.0/TLS client.ANC.com:5061;branch = z9hG4bK74bf9
Max-Forwards: 70
From: Alice<sips:[email protected]>;tag = 1234567
To: Bob<sips:[email protected]>
Call-ID: [email protected]
CSeq: 1 INVITE
Contact: <sips:[email protected]>
Allow: INVITE, ACK, CANCEL, OPTIONS, BYE, REFER, NOTIFY
Supported: replaces
Content-Type: application/sdp
Content-Length: ...
v = 0
o = Alice 2890844526 2890844526 IN IP4 client.ANC.com
s = Session SDP
c = IN IP4 client.ANC.com
t = 3034423619 0
m = audio 49170 RTP/AVP 0
a = rtpmap:0 PCMU/8000
さようなら
BYEは、確立されたセッションを終了するために使用される方法です。これは、セッションを終了するために発信者または着信者のいずれかが送信できるSIP要求です。
プロキシサーバーから送信することはできません。
BYEリクエストは通常、プロキシサーバーをバイパスしてエンドツーエンドでルーティングします。
BYEは、保留中のINVITEまたは確立されていないセッションに送信することはできません。
登録
REGISTERリクエストは、ユーザーエージェントの登録を実行します。このリクエストは、ユーザーエージェントからレジストラサーバーに送信されます。
REGISTERリクエストは、指定されたドメインの権限のあるレジストラに到達するまで転送またはプロキシされる場合があります。
それはAOR(レコードのアドレス)を運びます To 登録されているユーザーのヘッダー。
REGISTERリクエストには、期間(3600秒)が含まれています。
あるユーザーエージェントは、別のユーザーエージェントに代わってREGISTERリクエストを送信できます。これはとして知られていますthird-party registration。ここでは、From タグには、で識別された当事者に代わって登録を送信する当事者のURIが含まれています To ヘッダ。
キャンセル
CANCELは、確立されていないセッションを終了するために使用されます。ユーザーエージェントはこの要求を使用して、以前に開始された保留中の呼び出しの試行をキャンセルします。
これは、ユーザーエージェントまたはプロキシサーバーのいずれかによって送信できます。
キャンセルは hop by hop リクエスト、つまり、ユーザーエージェント間の要素を通過し、次のステートフル要素によって生成された応答を受信します。
ACK
ACKは、INVITEメソッドへの最終応答を確認するために使用されます。ACKは常にINVITEの方向に進みます。INVITEで使用できない場合、ACKにはSDP本体(メディア特性)が含まれる場合があります。
ACKを使用して、最初のINVITEですでに送信されているメディアの説明を変更することはできません。
ACKを受信するステートフルプロキシは、ACKを別のプロキシまたはユーザーエージェントにダウンストリームで転送する必要があるかどうかを判断する必要があります。
2xx応答の場合、ACKはエンドツーエンドですが、他のすべての最終応答の場合、ステートフルプロキシが含まれている場合はホップごとに機能します。
オプション
OPTIONSメソッドは、ユーザーエージェントまたはプロキシサーバーにその機能についてクエリを実行し、現在の可用性を検出するために使用されます。要求への応答には、ユーザーエージェントまたはサーバーの機能が一覧表示されます。プロキシがOPTIONSリクエストを生成することはありません。
拡張メソッド
申し込む
SUBSCRIBEは、特定のイベントに関する通知を取得する目的でサブスクリプションを確立するためにユーザーエージェントによって使用されます。
それは含まれています Expires サブスクリプションの期間を示すヘッダーフィールド。
期間が経過すると、サブスクリプションは自動的に終了します。
サブスクリプションは、ユーザーエージェント間のダイアログを確立します。
有効期限が切れる前にダイアログ内で別のSUBSCRIBEを送信することにより、再度サブスクリプションを行うことができます。
ユーザーからのサブスクリプションに対して200OKが受信されます。
ユーザーは、有効期限の値が0(ゼロ)の別のSUBSCRIBEメソッドを送信することで、サブスクライブを解除できます。
通知
NOTIFYは、特定のイベントの発生を取得するためにユーザーエージェントによって使用されます。通常、NOTIFYは、サブスクライバーと通知機能の間にサブスクリプションが存在する場合にダイアログ内でトリガーされます。
すべてのNOTIFYは、通知機能によって受信された場合、200OK応答を受け取ります。
NOTIFYには Event イベントを示すヘッダーフィールドと subscriptionstate サブスクリプションの現在の状態を示すヘッダーフィールド。
NOTIFYは、サブスクリプションの開始時と終了時に常に送信されます。
公開
PUBLISHは、イベント状態情報をサーバーに送信するためにユーザーエージェントによって使用されます。
PUBLISHは、イベント情報のソースが複数ある場合に最も役立ちます。
PUBLISHリクエストは、ダイアログで送信されないことを除いて、NOTIFYに似ています。
PUBLISHリクエストには、 Expires ヘッダーフィールドと Min-Expires ヘッダーフィールド。
参照
REFERは、ダイアログのURIにアクセスするために別のユーザーエージェントを参照するためにユーザーエージェントによって使用されます。
REFERには、 Refer-Toヘッダ。これは、REFERの必須ヘッダーです。
REFERは、ダイアログの内側または外側に送信できます。
A 202 Accepted 他のユーザーエージェントが参照を受け入れたことを示すREFER要求をトリガーします。
情報
INFOは、メディアセッションを確立した別のユーザーエージェントにコールシグナリング情報を送信するためにユーザーエージェントによって使用されます。
これはエンドツーエンドのリクエストです。
プロキシは常にINFOリクエストを転送します。
更新
UPDATEは、セッションが確立されていない場合にセッションの状態を変更するために使用されます。ユーザーは、UPDATEを使用してコーデックを変更できます。
セッションが確立されると、再招待を使用してセッションを変更/更新します。
PRACK
PRACKは、暫定応答(1XX)の信頼できる転送の受信を確認するために使用されます。
通常、PRACKは、クライアントが以下を含む暫定応答を受信したときに生成されます。 RSeq 信頼できるシーケンス番号と supported:100rel ヘッダ。
PRACKには(RSeq + CSeq)の値が含まれています rack ヘッダ。
PRACKメソッドは、確実に転送されることのない100試行応答を除くすべての暫定応答に適用されます。
PRACKにはメッセージ本文が含まれる場合があります。オファー/アンサー交換に使用できます。
メッセージ
SIPを使用してインスタントメッセージを送信するために使用されます。IMは通常、テキスト会話に従事する参加者によってリアルタイムで交換される短いメッセージで構成されます。
MESSAGEは、ダイアログ内またはダイアログ外に送信できます。
MESSAGEの内容は、メッセージ本文に MIME アタッチメント。
A 200 OK 通常、応答はメッセージが宛先に配信されたことを示すために受信されます。
SIP応答は、クライアントによって生成された要求に応答するために、ユーザーエージェントサーバー(UAS)またはSIPサーバーによって生成されたメッセージです。UACによる要求の再送信を防ぐことは、正式な承認である可能性があります。
応答には、UACが必要とする情報の追加のヘッダーフィールドが含まれる場合があります。
SIPには6つの応答があります。
1xxから5xxはHTTPから借用されており、6xxはSIPに導入されています。
1xxは provisional 応答と残りは final 反応。
S.No. | 機能と説明 |
---|---|
1 | 1xx:暫定的/情報的対応 情報応答は、 call progress。通常、応答はエンドツーエンドです(100回の試行を除く)。 |
2 | 2xx:成功への対応 このクラスの応答は、要求が受け入れられたことを示すためのものです。 |
3 | 3xx:リダイレクト応答 通常、これらのクラス応答は、INVITEに応答してリダイレクトサーバーによって送信されます。これらは、リダイレクトクラス応答とも呼ばれます。 |
4 | 4xx:クライアント障害応答 クライアントエラー応答は、UAC側から一部のエラーが識別されたため、要求を実行できないことを示しています。 |
5 | 5xx:サーバー障害応答 このクラス応答は、サーバーのエラーのために要求を処理できないことを示すために使用されます。 |
6 | 6xx:グローバル障害応答 この応答クラスは、要求が試行された場所で要求が失敗することをサーバーが認識していることを示します。したがって、リクエストを他の場所に送信しないでください。 |
ヘッダーは、メッセージに関する情報を伝達するSIPメッセージのコンポーネントです。これは、一連のヘッダーフィールドとして構成されています。
ほとんどの場合、SIPヘッダーフィールドはHTTPヘッダーフィールドと同じルールに従います。ヘッダーフィールドは次のように定義されますHeader: field、ここで、Headerはヘッダーフィールド名を表すために使用され、fieldは情報を含むトークンのセットです。各フィールドは、フィールド名とそれに続くコロン( ":")およびフィールド値(つまり、field-name: field-value)。
SIPヘッダー-コンパクトフォーム
多くの一般的なSIPヘッダーフィールドは、ヘッダーフィールド名が単一の小文字で示されるコンパクトな形式です。いくつかの例を以下に示します-
ヘッダ | コンパクトフォーム |
---|---|
に | T |
経由 | V |
コールID | 私 |
連絡先 | M |
から | F |
件名 | S |
コンテンツの長さ | 私 |
SIPヘッダー形式
次の画像は、一般的なSIPヘッダーの構造を示しています。
ヘッダーは、SIPでの使用法に応じて次のように分類されます-
- 要求と応答
- リクエストのみ
- 応答のみ
- メッセージ本文
SDPはSessionDescriptionProtocolの略です。これは、ネットワークを介して参加者が理解できる形式でマルチメディアセッションを説明するために使用されます。この説明に応じて、当事者は会議に参加するかどうか、またはいつ、どのように会議に参加するかを決定します。
会議の所有者は、セッションの説明(所有者の名前、セッションの名前、コーディング、タイミングなど)を含むマルチキャストメッセージを送信することにより、ネットワークを介して会議をアドバタイズします。これらの情報に応じて、アドバタイズの受信者セッションへの参加について決定を下します。
SDPは通常、一般にSIPと呼ばれるSession InitiationProtocolの本体部分に含まれています。
SDPはRFC2327で定義されています。SDPメッセージは、フィールドと呼ばれる一連の行で構成され、その名前は1つの小文字で省略され、解析を簡素化するために必要な順序になっています。
SDPの目的
SDPの目的は、マルチメディアセッションでメディアストリームに関する情報を伝達し、参加者が特定のセッションの情報に参加または収集できるようにすることです。
SDPは、構造化された短いテキスト記述です。
セッションの名前と目的、メディア、プロトコル、コーデック形式、タイミング、およびトランスポート情報を伝達します。
暫定参加者はこれらの情報を確認し、セッションに参加するかどうか、および参加することを決定した場合はいつどのようにセッションに参加するかを決定します。
このフォーマットには、<type> = <value>の形式のエントリがあります。ここで、<type>は一意のセッションパラメータを定義し、<value>はそのパラメータに特定の値を提供します。
SDPメッセージの一般的な形式は次のとおりです。
x = parameter1 parameter2 ... parameterN
行は、xなどの単一の小文字で始まります。文字と=の間にスペースが存在することはなく、各パラメーターの間にスペースが1つだけ存在します。各フィールドには、定義された数のパラメーターがあります。
セッションの説明パラメータ
セッションの説明(*はオプションを示します)
- v =(プロトコルバージョン)
- o =(所有者/作成者およびセッション識別子)
- s =(セッション名)
- i = *(セッション情報)
- u = *(説明のURI)
- e = *(メールアドレス)
- p = *(電話番号)
- c = *(接続情報-すべてのメディアに含まれている場合は不要)
- b = *(帯域幅情報)
- z = *(タイムゾーン調整)
- k = *(暗号化キー)
- a = *(0個以上のセッション属性行)
プロトコルバージョン
v =フィールドには、SDPバージョン番号が含まれます。SDPの現在のバージョンは0であるため、有効なSDPメッセージは常にv = 0で始まります。
原点
o =フィールドには、セッションの発信者とセッション識別子に関する情報が含まれています。このフィールドは、セッションを一意に識別するために使用されます。
フィールドには-が含まれます
o = <ユーザー名> <セッションID> <バージョン> <ネットワークタイプ> <アドレスタイプ>
ザ・ username パラメータには、発信者のログインまたはホストが含まれます。
ザ・ session-id パラメータは、ネットワークタイムプロトコル(NTP)のタイムスタンプ、または一意性を確保するために使用される乱数です。
ザ・ version セッションが変更されるたびに増加する数値フィールドであり、NTPタイムスタンプにすることもお勧めします。
ザ・ network-typeインターネットでは常にINです。address-typeパラメーターは、ドット付き10進形式または完全修飾ホスト名のIPv4またはIPv6アドレスの場合はIP4またはIP6です。
セッション名と情報
s =フィールドには、セッションの名前が含まれています。ゼロ以外の文字数を含めることができます。オプションのi =フィールドには、セッションに関する情報が含まれています。任意の数の文字を含めることができます。
URI
オプションのu =フィールドには、セッションに関する詳細情報を含むURI(Uniform Resource Indicator)が含まれています
メールアドレスと電話番号
オプションのe =フィールドには、セッションのホストの電子メールアドレスが含まれます。オプションのp =フィールドには、電話番号が含まれています。
接続データ
c =フィールドには、メディア接続に関する情報が含まれています。
フィールドには-が含まれます
c = <ネットワークタイプ> <アドレスタイプ> <接続アドレス>
ザ・ network-type パラメータはインターネットのINとして定義されています。
ザ・ address-type IPv4アドレスの場合はIP4、IPv6アドレスの場合はIP6として定義されます。
ザ・ connection-address メディアパケットを送信するIPアドレスまたはホストであり、マルチキャストまたはユニキャストのいずれかです。
マルチキャストの場合、接続アドレスフィールドには-が含まれます
connection-address = base-multicast-address / ttl / number-of-addresses
どこ ttl は存続時間の値であり、アドレス数は、ベースマルチキャストアドレスから始まる連続したマルチキャストアドレスの数を示します。
帯域幅
オプションのb =フィールドには、必要な帯域幅に関する情報が含まれています。それは次の形式です-
b =修飾子:帯域幅-値
時間、繰り返し時間、およびタイムゾーン
t =フィールドには、セッションの開始時刻と停止時刻が含まれます。
t =開始時間停止時間
オプションのr =フィールドには、NTPまたは日(d)、時間(h)、または分(m)のいずれかで指定できる繰り返し時間に関する情報が含まれています。
オプションのz =フィールドには、タイムゾーンオフセットに関する情報が含まれています。このフィールドは、発生しているセッションが夏時間から標準時間への変更、またはその逆の変更にまたがる場合に使用されます。
メディアアナウンス
オプションのm =フィールドには、メディアセッションのタイプに関する情報が含まれています。フィールドには-が含まれます
m =メディアポートトランスポートフォーマットリスト
メディアパラメータは、オーディオ、ビデオ、テキスト、アプリケーション、メッセージ、画像、またはコントロールのいずれかです。portパラメータには、ポート番号が含まれています。
トランスポートパラメータには、使用されるトランスポートプロトコルまたはRTPプロファイルが含まれます。
format-listには、メディアに関する詳細情報が含まれています。通常、RTPオーディオビデオプロファイルで定義されたメディアペイロードタイプが含まれています。
Example:
m = audio 49430 RTP/AVP 0 6 8 99
これら3つのコーデックの1つは、オーディオメディアセッションに使用できます。3つのオーディオチャネルを確立することが目的の場合、3つの別々のメディアフィールドが使用されます。
属性
オプションのa =フィールドには、先行するメディアセッションの属性が含まれます。このフィールドは、extend SDP to provide more information about the media。SDPユーザーが完全に理解していない場合、属性フィールドは無視できます。メディアフィールドにリストされているメディアペイロードタイプごとに、1つ以上の属性フィールドを含めることができます。
SDPの属性は次のいずれかになります
- セッションレベル、または
- メディアレベル。
セッションレベルとは、属性がSDPの最初のメディア行の前にリストされていることを意味します。この場合、属性はその下のすべてのメディア行に適用されます。
メディアレベルとは、メディア行の後にリストされていることを意味します。この場合、属性はこの特定のメディアストリームにのみ適用されます。
SDPには、セッションレベルとメディアレベルの両方の属性を含めることができます。同じ属性が両方として表示される場合、メディアレベル属性はその特定のメディアストリームのセッションレベル属性を上書きします。接続データフィールドは、セッションレベルまたはメディアレベルのいずれでもかまいません。
SDPの例
以下に示すのは、RFC2327から取得したセッションの説明の例です。
v = 0
o = mhandley2890844526 2890842807 IN IP4 126.16.64.4
s = SDP Seminar
i = A Seminar on the session description protocol
u = http://www.cs.ucl.ac.uk/staff/M.Handley/sdp.03.ps
e = [email protected](Mark Handley)
c = IN IP4 224.2.17.12/127
t = 2873397496 2873404696
a = recvonly
m = audio 49170 RTP/AVP 0
m = video 51372 RTP/AVP 31
m = application 32416udp wb
a = orient:portrait
SIPでのSDPの使用は、SDPオファー回答RFC3264に記載されています。SIPのデフォルトのメッセージ本文タイプは application/sdp。
発呼者は、SDPで、通常はINVITEまたはACKで受信するメディア機能を一覧表示します。
着信側は、INVITEへの200OK応答にメディア機能をリストします。
SDPの一般的なSIP使用には、バージョン、発信元、件名、時間、接続、および1つ以上のメディアと属性のフィールドが含まれます。
件名と時間のフィールドはSIPでは使用されませんが、互換性のために含まれています。
SDP標準では、件名フィールドは必須フィールドであり、少なくとも1文字を含める必要があります。件名がない場合は、s =-にすることをお勧めします。
時間フィールドは通常、t = 00に設定されます。SIPは、接続、メディア、および属性フィールドを使用して、UA間のセッションをセットアップします。
オリジンフィールドは、SIPでの使用が制限されています。
セッションIDは通常、SIPセッション全体を通じて一定に保たれます。
バージョンは、SDPが変更されるたびにインクリメントされます。送信されるSDPが以前に送信されたものから変更されていない場合、バージョンは同じに保たれます。
使用するメディアセッションとコーデックのタイプは接続ネゴシエーションの一部であるため、SIPはSDPを使用して複数の代替メディアタイプを指定し、それらのメディアタイプを選択的に受け入れるか拒否することができます。
オファー/アンサー仕様、RFC 3264では、各メディアフィールドにa = rtpmap:を含む属性を使用することを推奨しています。SDP応答の対応するメディアフィールドのポート番号をゼロに設定すると、メディアストリームが拒否されます。
例
次の例では、発信者のTeslaが、最初のINVITEで伝送されるSDPに2つの可能なオーディオコーデックとビデオコーデックを使用してオーディオおよびビデオコールを設定したいと考えています。
v = 0
o = John 0844526 2890844526 IN IP4 172.22.1.102
s = -
c = IN IP4 172.22.1.102
t = 0 0
m = audio 6000 RTP/AVP 97 98
a = rtpmap:97 AMR/16000/1
a = rtpmap:98 AMR-WB/8000/1
m = video 49172 RTP/AVP 32
a = rtpmap:32 MPV/90000
コーデックは、RTP / AVPプロファイル番号97、98によって参照されます。
着信側のMarryがコールに応答し、最初のメディアフィールドに2番目のコーデックを選択し、2番目のメディアフィールドを拒否します。AMRセッションのみが必要です。
v = 0
o = Marry 2890844526 2890844526 IN IP4 172.22.1.110
s = -
c = IN IP4 200.201.202.203
t = 0 0
m = audio 60000 RTP/AVP 8
a = rtpmap:97 AMR/16000
m = video 0 RTP/AVP 32
この音声のみの通話が受け入れられない場合、トムはACKを送信し、次にBYEを送信して通話をキャンセルします。それ以外の場合は、オーディオセッションが確立され、RTPパケットが交換されます。
この例が示すように、メディアフィールドの数と順序が維持されない限り、発呼側は、どのメディアセッションが着呼側によって受け入れられ、拒否されているかを確実に知ることはできません。
オファー/アンサールールは、次のセクションに要約されています。
オファーを生成するためのルール
SDPオファーには、必要なすべてのSDPフィールドが含まれている必要があります(これには、v =、o =、s =、c =、およびt =が含まれます)。これらはSDPの必須フィールドです。
通常、メディアフィールド(m =)が含まれますが、必須ではありません。メディア行には、優先順にリストされたすべてのコーデックが含まれています。これに対する唯一の例外は、エンドポイントが膨大な数のコーデックをサポートしている場合であり、受け入れられる可能性が最も高い、または最も好ましいコーデックをリストする必要があります。さまざまなメディアタイプには、オーディオ、ビデオ、テキスト、MSRP、BFCPなどがあります。
回答を生成するためのルール
オファーに対するSDP回答は、次のルールに従って作成する必要があります-
回答には、回答と同じ順序で同じ数のm =行が必要です。
ポート番号を0に設定すると、個々のメディアストリームを拒否できます。
ストリームは、ゼロ以外のポート番号を送信することによって受け入れられます。
各メディアタイプにリストされているペイロードは、オファーにリストされているペイロードのサブセットである必要があります。
動的ペイロードの場合、各方向で同じ動的ペイロード番号を使用する必要はありません。通常、単一のペイロードのみが選択されます。
セッションを変更するためのルール
どちらの当事者も、セッションを変更するために別のオファー/アンサー交換を開始できます。セッションを変更する場合は、次のルールに従う必要があります-
発信元(o =)の回線バージョン番号は、最後に送信されたものと同じである必要があります。これは、このSDPが前の交換と同一であることを示します。または、1ずつインクリメントされて、解析する必要がある新しいSDPを示します。
オファーには既存のすべてのメディアラインが含まれている必要があり、それらは同じ順序で送信される必要があります。
m =行リストの最後にメディアストリームを追加できます。
ポート番号を0に設定することにより、既存のメディアストリームを削除できます。このメディア回線は、SDPおよびこのセッションの今後のすべてのオファー/アンサー交換に残る必要があります。
通話保留
通話中の一方の通話者は、もう一方の通話者を一時的に保留にすることができます。これは、元のINVITEと同じSDPを持つINVITEを送信することによって行われます。a = sendonly 属性が存在します。
呼び出しは、別のINVITEを送信することによって再びアクティブになります。 a = sendrecv属性が存在します。次の図は、コールホールドのコールフローを示しています。
Personal mobilityは、複数のデバイスにわたって一定の識別子を持つ機能です。SIPは、REGISTERメソッドを使用して基本的なパーソナルモビリティをサポートします。これにより、モバイルデバイスはIPアドレスとインターネットへの接続ポイントを変更し、着信コールを受信できます。
SIPはサポートすることもできます service mobility –モバイル時に同じサービスを維持するユーザーの能力
ハンドオーバー中のSIPモビリティ(プレコール)
デバイスは、単純な一口登録によって、その連絡先URIをレコードのアドレスにバインドします。デバイスのIPアドレスに応じて、登録により、この情報がSIPネットワークで自動的に更新されることが許可されます。
ハンドオーバー中、ユーザーエージェントは異なるオペレーター間をルーティングします。そこでは、別のサービスプロバイダーのAORとして連絡先に再度登録する必要があります。
たとえば、次のコールフローの例を見てみましょう。新しいサービスプロバイダーで新しいSIPURIを一時的に受信したUA。次に、UAは二重登録を実行します-
最初の登録は、デバイスの連絡先URIを新しいサービスプロバイダーのAORURIにバインドする新しいサービスオペレーターで行われます。
2番目のREGISTERリクエストは、元のサービスプロバイダーにルーティングされ、新しいサービスプロバイダーのAORを連絡先URIとして提供します。
コールフローの後半に示すように、要求が元のサービスプロバイダーのネットワークに着信すると、INVITEは新しいサービスプロバイダーにリダイレクトされ、新しいサービスプロバイダーはそのコールをユーザーにルーティングします。
最初の登録の場合、デバイスURIを含むメッセージは次のようになります。
REGISTER sip:visited.registrar1.com SIP/2.0
Via: SIP/2.0/UDP 172.22.1.102:5060;branch = z9hG4bK97a7ea349ce0fca
Max-Forwards: 70
To: Tom <sip:[email protected]>
From: Tom <sip:[email protected]>;tag = 72d65a24
Call-ID: [email protected]
CSeq: 1 REGISTER
Contact: <sip:[email protected]:5060>
Expires: 600000
Content-Length: 0
ローミングURIを使用した2番目の登録メッセージは次のようになります。
REGISTER sip:home.registrar2.in SIP/2.0
Via: SIP/2.0/UDP 172.22.1.102:5060;branch = z9hG4bKah4vn2u
Max-Forwards: 70
To: Tom <sip:[email protected]>
From: Tom <sip:[email protected]>;tag = 45375
Call-ID:[email protected]
CSeq: 6421 REGISTER
Contact: <sip:[email protected]>
Content-Length: 0
上の図に示されている最初のINVITEは、sip:registrar2.inに送信されます。2番目のINVITEはsipに送信されます:sip:[email protected]、これはに転送されますsip:[email protected]。トムに到達し、セッションを確立できるようにします。定期的に両方の登録を更新する必要があります。
通話中のモビリティ(再招待)
ユーザーエージェントは、あるネットワークから別のネットワークにスワップするときに、セッション中にIPアドレスを変更する場合があります。ダイアログのre-INVITEを使用して連絡先URIを更新し、SDPのメディア情報を変更できるため、基本的なSIPはこのシナリオをサポートします。
下の図に示されているコールフローを見てください。
ここで、トムは新しいネットワークを検出します。
DHCPを使用して新しいIPアドレスを取得し、
re-INVITEを実行して、新しいIPアドレスへのシグナリングとメディアフローを許可します。
UAが両方のネットワークからメディアを受信できる場合、中断はごくわずかです。そうでない場合は、いくつかのメディアパケットが失われ、通話がわずかに中断される可能性があります。
re-INVITEは次のように表示されます-
INVITE sip:[email protected] SIP/2.0
Via: SIP/2.0/UDP 172.22.1.102:5060;branch = z9hG4bK918f5a84fe6bf7a
Max-Forwards: 70
To: <sip:[email protected]>
From: sip:[email protected];tag = 70133df4
Call-ID: 76d4861c19c
CSeq: 1 INVITE
Accept: application/sdp
Accept-Language: en
Allow: INVITE,ACK,CANCEL,BYE,INFO,OPTIONS,REFER,NOTIFY,SUBSCRIBE
Contact: <sip:172.22.1.102:5060>;
Content-Type: application/sdp
Content-Length: 168
v = 0
o = PPT 40467 40468 IN IP4 192.168.2.1
s = -
c = IN IP4 192.168.2.1
b = AS:49
t = 0 0
b = RR:0
b = RS:0
a = rtpmap:97 AMR/8000/1
m = audio 6000 RTP/AVP 96
a = fmtp:102 0-15
a = ptime:20
a = maxptime:240
re-INVITEには、ViaおよびContactヘッダーフィールドとSDPメディア情報にBowditchの新しいIPアドレスが含まれています。
ミッドコールでのモビリティ(ヘッダーの置換あり)
ミッドコールモビリティでは、実際のルートセット(SIPメッセージが通過する必要のあるSIPプロキシのセット)を変更する必要があります。通話中のモビリティでre-INVITEを使用することはできません
たとえば、NATトラバーサルにプロキシが必要な場合は、連絡先URIを変更する必要があります—新しいダイアログを作成する必要があります。したがって、既存のセッションを識別するReplacesヘッダーを使用して新しいINVITEを送信する必要があります。
Note − AとBの両方が通話中であり、Aが置換ヘッダー(既存のダイアログと一致する必要がある)を含む別のINVITE(たとえば、Cから)を取得した場合、AはINVITEを受け入れ、Bとのセッションを終了し、すべてのリソースをに転送する必要があります。新しく形成されたダイアログ。
コールフローを次の図に示します。これは、re-INVITEを使用した以前のコールフローと似ていますが、置換を伴うINVITEが受け入れられたときに、BYEが自動的に生成されて既存のダイアログが終了する点が異なります。
このシナリオで注意すべき点は次のとおりです-
トムとジェリーの間の既存のダイアログには、以前にアクセスしたプロキシサーバーが含まれています。
新しいワイヤレスネットワークを使用する新しいダイアログには、新しくアクセスしたプロキシサーバーを含める必要があります。
その結果、Replacesを使用したINVITEがTomによって送信されます。これにより、新しく訪問したプロキシサーバーを含み、古い訪問したプロキシサーバーを含まない新しいダイアログが作成されます。
JerryがINVITEを受け入れると、BYEが自動的に送信され、セッションに関与しなくなった古い訪問済みプロキシサーバーを経由する古いダイアログが終了します。
結果のメディアセッションは、INVITEのSDPからのトムの新しいIPアドレスを使用して確立されます。
サービスモビリティ
SIPのサービスは、プロキシまたはUAのいずれかで提供できます。ユーザーのデバイスが同じサービスで同じように構成されていない限り、パーソナルモビリティとともにサービスモビリティを提供することは困難な場合があります。
SIPは、インターネットを介したサービスモビリティを簡単にサポートできます。インターネットに接続している場合、インドで一連のプロキシを使用するように構成されたUAは、ヨーロッパでローミングしているときにもそれらのプロキシを使用できます。メディアは常に2つのUA間を直接流れ、SIPプロキシサーバーを通過しないため、メディアセッションの品質に影響はありません。
エンドポイント常駐サービスは、エンドポイントがインターネットに接続されている場合にのみ利用できます。エンドポイントに実装されているコール転送サービスなどの終了サービスは、エンドポイントが一時的にインターネット接続を失った場合に失敗します。したがって、一部のサービスは、SIPプロキシサーバーを使用してネットワークに実装されます。
プロキシサーバーが単一のSIPコールを複数のSIPエンドポイントに転送する場合があります。このプロセスはフォークとして知られています。ここでは、1回の呼び出しで同時に多くのエンドポイントを呼び出すことができます。
SIPフォークを使用すると、デスクフォンをソフトフォンまたはモバイルのSIP電話と同時に鳴らすことができるため、どちらのデバイスからでも簡単に電話をかけることができます。
一般に、オフィスでは、上司が電話に出られない、または離れることができないと仮定すると、SIPフォークにより、秘書は自分の内線の電話に応答できます。
ステートフルプロキシが利用可能であれば、受信した多数のプロキシから実行して応答する必要があるため、フォークが可能になります。
フォークには2つのタイプがあります-
- パラレルフォーク
- シーケンシャルフォーク
パラレルフォーク
このシナリオでは、プロキシサーバーは一度に2つのデバイス(UA2、UA3)にINVITEをフォークします。両方のデバイスで180の呼び出し音が生成され、呼び出しを受信した人は200OKを生成します。最初に発信者に到達する応答(UA2を想定)は、UA2とのセッションを確立します。その他の応答では、CANCELがトリガーされます。
発信者が両方の応答を同時に受信した場合、q値に基づいて、応答を転送します。
シーケンシャルフォーク
このシナリオでは、プロキシサーバーはINVITEを1つのデバイス(UA2)にフォークします。その時点でUA2が使用できないかビジーである場合、プロキシはそれを別のデバイス(UA3)にフォークします。
ブランチ-IDとタグ
ブランチIDは、プロキシがフォークされたリクエストへの応答を照合するのに役立ちます。ブランチIDがないと、プロキシサーバーはフォークされた応答を理解できません。Branch-idはViaヘッダーで利用可能になります。
タグはUACによって使用され、異なるUASからの複数の最終応答を区別します。UASは、リクエストがフォークされているかどうかを解決できません。したがって、タグを追加する必要があります。
プロキシは、最終応答を生成する場合にタグを追加することもできます。転送する要求または応答にタグを挿入することはありません。
1つのリクエストが複数のプロキシサーバーによってフォークされる可能性もあります。したがって、フォークするプロキシは、作成したブランチに独自の一意のIDを追加する必要があります。
コールレッグとコールID
コールレッグとは、2つのユーザーエージェント間の1対1のシグナリング関係を指します。コールIDは、コールを参照するSIPメッセージで伝送される一意の識別子です。コールは、コールレッグのコレクションです。
UACは、INVITEを送信することから始まります。フォークが原因で、異なるUAから複数の200OKを受け取る場合があります。それぞれが同じコール内の異なるコールレッグに対応します。
したがって、コールはコールレッグのグループです。コールレッグとは、UA間のエンドツーエンド接続を指します。
コールレッグの2方向のCSeqスペースは独立しています。単一の方向では、シーケンス番号はトランザクションごとに増分されます。
ボイスメール
ボイスメールは、今日のエンタープライズユーザーにとって非常に一般的です。それは電話アプリケーションです。着信側が不在または着信できない場合、PBXは発呼側にボイスメッセージを残すようにアナウンスします。
着信側の番号に到達できない場合、ユーザーエージェントは3xx応答を受け取るか、ボイスメールサーバーにリダイレクトします。ただし、使用するメールボックス、つまり、再生するグリーティングと録音されたメッセージの保存場所をボイスメールシステムに示すには、何らかのSIP拡張機能が必要です。これを達成するための2つの方法があります-
SIPヘッダーフィールド拡張を使用する
Request-URIを使用してこの情報を通知する
ユーザーのために仮定します sip:[email protected] ボイスメールを提供しているsip:voicemail.tutorialspoint.comにボイスメールシステムがあります。ボイスメールサーバーに転送されたときのINVITEのRequest-URIは次のようになります。
sip:voicemail.tutorialspoint.com;target = sip:[email protected];cause = 486
次の図は、Request-URIがメールボックス識別子と理由(ここでは486)をどのように伝達するかを示しています。
ご存知のように、プロキシサーバーはステートレスまたはステートフルのいずれかになります。ここでは、この章で、プロキシサーバーとSIPルーティングについて詳しく説明します。
ステートレスプロキシサーバー
ステートレスプロキシサーバーは、受信したメッセージを転送するだけです。この種のサーバーは、通話やトランザクションの情報を保存しません。
- ステートレスプロキシは、転送されるとSIP要求を忘れます。
- トランザクションはステートレスプロキシを介して高速になります。
ステートフルプロキシサーバー
ステートフルプロキシサーバーは、受信したすべての要求と応答を追跡します。必要に応じて、保存された情報を将来使用することができます。反対側からの応答を受信しない場合は、要求を再送信できます。
ステートフルプロキシは、転送後にリクエストを記憶するため、事前ルーティングに使用できます。ステートフルプロキシはトランザクション状態を維持します。トランザクションはトランザクションの状態を意味し、not状態を呼び出します。
ステートフルプロキシの場合、トランザクションはステートレスほど高速ではありません。
ステートフルプロキシは、必要に応じてフォークして再送信できます(例:コールフォワードビジー)。
経由および記録ルート
記録ルート
Record-Routeヘッダーは、同じcall-idに対する後続のリクエストのパスに入れたいプロキシによるリクエストに挿入されます。その後、ユーザーエージェントは、後続のリクエストをルーティングするために使用します。
経由
Viaヘッダーは、ループを検出し、応答がクライアントに戻る方法を見つけるのに役立つように、サーバーによって要求に挿入されます。これは、目的地に到達するための応答のみに役立ちます。
UA自身が、リクエストの送信中に独自のアドレスを生成し、Viaヘッダーフィールドに追加します。
リクエストを転送するプロキシは、独自のアドレスを含むViaヘッダーフィールドをViaヘッダーフィールドのリストの一番上に追加します。
要求への応答を生成するプロキシまたはUAは、すべてのViaヘッダーフィールドを要求から順番に応答にコピーしてから、上部のViaヘッダーフィールドで指定されたアドレスに応答を送信します。
応答を受信するプロキシは、上部のViaヘッダーフィールドをチェックし、自身のアドレスと一致します。一致しない場合、応答は破棄されています。
次に、一番上のViaヘッダーフィールドが削除され、応答は次のViaヘッダーフィールドで指定されたアドレスに転送されます。
Viaヘッダーフィールドには、プロトコル名、バージョン番号、およびトランスポート(SIP / 2.0 / UDP、SIP / 2.0 / TCPなど)が含まれ、ポート番号と、received、rport、branchなどのパラメーターが含まれます。
UAまたはプロキシが上部のViaヘッダーフィールドで指定されたアドレスとは異なるアドレスから要求を受信した場合、受信したタグがViaヘッダーフィールドに追加されます。
ブランチパラメータは、UAとプロキシによってViaヘッダーフィールドに追加されます。これは、Request-URI、およびTo、From、Call-ID、CSeq番号のハッシュ関数として計算されます。
SIP(ソフトフォン)とPSTN(旧電話)はどちらも異なるネットワークであり、異なる言語を話します。したがって、これら2つのネットワーク間で通信するには、トランスレータ(ここではゲートウェイ)が必要です。
SIP電話がPSTNゲートウェイを介してPSTNに電話をかける方法を示す例を見てみましょう。
この例では、トム (sip:[email protected]) は一口電話で、ジェリーはグローバル電話番号+91401234567を使用します。
ゲートウェイを介したPSTNへのSIP
次の図は、ゲートウェイを介したSIPからPSTNへのコールフローを示しています。
以下に示すのは、SIP電話からPSTNに電話をかけるときに行われるすべてのプロセスの段階的な説明です。
まず、(Tom)SIP電話がグローバル番号+91401234567をダイヤルして、ジェリーに連絡します。SIPユーザーエージェントはそれをグローバル番号として理解し、DNSを使用してそれをrequest-uriに変換し、要求をトリガーします。
SIP電話は、INVITEをゲートウェイに直接送信します。
ゲートウェイは、PSTN内の次の電話交換機へのSS7 ISUPトランクを選択することにより、PSTNへの通話を開始します。
INVITEからダイヤルされた数字は、ISUPIAMにマッピングされます。ISUPアドレス完了メッセージ(ACM)は、トランクが作成されたことを示すためにPSTNによって返送されます。
電話は着信音を生成し、電話交換機に行きます。ゲートウェイは、ゲートウェイがPSTNからのオーディオをブリッジするために使用するRTPポートを示すSDPを含む183 SessionProgress応答にACMをマップします。
183を受信すると、発信者のUACはゲートウェイから送信されたRTPパケットの受信を開始し、発信者に音声を提示して、発信者がPSTNで進行中であることを認識します。
着信側が電話に応答すると、通話が完了します。これにより、電話交換機は応答メッセージ(ANM)をゲートウェイに送信します。
次に、ゲートウェイはPSTNオーディオ接続を両方向に切断し、200OK応答を発信者に送信します。RTPメディアパスはすでに確立されているため、ゲートウェイは183でSDPに応答しますが、RTP接続は変更されません。
UACはACKを送信して、SIPシグナリング交換を完了します。ISUPには同等のメッセージがないため、ゲートウェイがACKを吸収します。
呼び出し元はBYEをゲートウェイに送信して終了します。ゲートウェイは、BYEをISUPリリースメッセージ(REL)にマップします。
ゲートウェイは200OKをBYEに送信し、PSTNからRLCを受信します。
コーデックは、coder-decoderの略で、2つの基本的な操作を実行します-
まず、アナログ音声信号を同等のデジタル形式に変換して、簡単に送信できるようにします。
その後、圧縮されたデジタル信号を元のアナログ形式に変換して、再生できるようにします。
市場には多くのコーデックがあります。無料のものもあれば、ライセンスが必要なものもあります。コーデックは音質が異なり、それに応じて帯域幅も異なります。
電話やゲートウェイなどのハードウェアデバイスは、いくつかの異なるコーデックをサポートしています。お互いに話している間、彼らはどのコーデックを使用するかを交渉します。
ここでは、この章で、広く使用されているいくつかの一般的なSIPオーディオコーデックについて説明します。
G.711
G.711は、デジタルテレフォニーで使用するために1972年にITUによって導入されたコーデックです。コーデックには2つのバリエーションがあります。A-Law ヨーロッパや国際電話リンクで使用されています、 uLaw アメリカと日本で使われています。
G.711は対数圧縮を使用します。各16ビットサンプルを8ビットに圧縮するため、1:2の圧縮率を実現します。
ビットレートは一方向で64kbit / sであるため、通話は128 kbit / sを消費します。
G.711は、PSTNネットワークで使用されるコーデックと同じであるため、最高の音声品質を提供します。ただし、他のコーデックよりも多くの帯域幅を消費します。
これは、多くの帯域幅を利用できるローカルエリアネットワークで最適に機能します。
G.729
G.729は、帯域幅要件が低いコーデックです。それは良いオーディオ品質を提供します。
コーデックは、オーディオを10ミリ秒の長さのフレームにエンコードします。サンプリング周波数が8kHzの場合、10msフレームには80のオーディオサンプルが含まれます。
コーデックアルゴリズムは各フレームを10バイトにエンコードするため、結果のビットレートは一方向で8 kbit / sになります。
G.729はライセンスされたコーデックです。このコーデックを使用したいエンドユーザーは、それを実装するハードウェア(VoIP電話またはゲートウェイ)を購入する必要があります。
G.729の頻繁に使用されるバリアントはG.729aです。元のコーデックとのワイヤ互換性がありますが、CPU要件は低くなります。
G.723.1
G.723.1は、28.8および33 kbit / sのモデムリンクを介した通話を許可するコーデックを設計することを目的としてITUが発表した競争の結果です。
G.723.1には2つのバリエーションがあります。どちらも30ミリ秒のオーディオフレーム(つまり240サンプル)で動作しますが、アルゴリズムは異なります。
最初のバリアントのビットレートは6.4kbit / sですが、2番目のバリアントのビットレートは5.3 kbit / sです。
2つのバリアントのエンコードされたフレームは、それぞれ24バイトと20バイトの長さです。
GSM 06.10
GSM 06.10は、GSMモバイルネットワーク用に設計されたコーデックです。GSMフルレートとも呼ばれます。
GSMコーデックのこのバリアントは自由に使用できるため、オープンソースのVoIPアプリケーションでよく見られます。
コーデックは20ミリ秒の長さのオーディオフレーム(つまり160サンプル)で動作し、各フレームを33バイトに圧縮するため、結果のビットレートは13 kbit /になります。
バックツーバックユーザーエージェント(B2BUA)は、SIPアプリケーションの論理ネットワーク要素です。これは、SIPリクエストを受信し、リクエストを再定式化して、新しいリクエストとして送信するタイプのSIPUAです。
プロキシサーバーとは異なり、ダイアログの状態を維持し、確立したダイアログで送信されるすべての要求に参加する必要があります。B2BUAは、SIPのエンドツーエンドの性質を破ります。
B2BUA –どのように機能しますか?
B2BUAエージェントは、通話の2つのエンドポイント間で動作し、通信チャネルを2つに分割します call legs。B2BUAは、UACとUASを連結したものです。通話の両端間のすべてのSIPシグナリングに参加し、確立しました。ダイアログサービスプロバイダーで利用可能なB2BUAは、いくつかの付加価値機能を実装する場合があります。
発信コールレッグでは、B2BUAはユーザーエージェントサーバー(UAS)として機能し、宛先エンドへのユーザーエージェントクライアント(UAC)として要求を処理し、エンドポイント間のシグナリングを連続して処理します。
B2BUAは、処理する呼び出しの完全な状態を維持します。B2BUAの各側は、RFC3261で指定されている標準のSIPネットワーク要素として動作します。
B2BUAの機能
B2BUAは以下の機能を提供します-
通話管理(請求、自動通話切断、通話転送など)
ネットワークインターワーキング(おそらくプロトコル適応を伴う)
ネットワーク内部(プライベートアドレス、ネットワークトポロジなど)の非表示
多くの場合、B2BUAは、セッションを完全に制御するためにメディアストリームをブリッジするために、メディアゲートウェイにも実装されます。
B2BUAの例
多くの構内交換機(PBX)エンタープライズ電話システムには、B2BUAロジックが組み込まれています。
一部のファイアウォールにはALG(Application Layer Gateway)機能が組み込まれているため、ファイアウォールは高レベルのセキュリティを維持しながらSIPおよびメディアトラフィックを承認できます。
B2BUAのもう1つの一般的なタイプは、セッションボーダーコントローラー(SBC)として知られています。