SIP-モビリティ
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アドレスが含まれています。
Midcallでのモビリティ(ヘッダーの置換あり)
ミッドコールモビリティでは、実際のルートセット(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プロキシサーバーを使用してネットワークに実装されます。