ICE コネクションステート機能¶
概要¶
ICE コネクションステート機能は Sora に ICE コネクションによる状態管理を持たせた機能です。
前提¶
この機能はクライアント側が意識する必要はありません。
挙動¶
Sora は WebRTC が確立した後に TURN 上で ICE コネクションステートを更新し続けます。
ステートの更新には STUN Binding-Request と STUN Binding-Success を利用します。
Sora は 2.5 秒間隔で
STUN Binding-Requestをクライアントへ送りますSTUN Binding-Successが 2.5 秒以内に一度も返ってこない場合、状態をconnectedからcheckingへ遷移します
状態が
checkingへ遷移した場合、 Sora は 1 秒間隔でSTUN Binding-Requestをクライアントへ送りますSTUN Binding-Successが 5 秒以内に一度も返ってこない場合、状態を checking から disconnected へ遷移しますこの 5 秒は
sora.confにてice_connection_state_disconnected_timeoutで変更できます
状態が
disconnectedに遷移した場合、 Sora は 50 ミリ秒間隔でSTUN Binding-Requestをクライアントへ送りますSTUN Binding-Successが 10 秒以内に一度も返ってこない場合、状態をdisconnectedからfailedへ遷移しますこの 10 秒は
sora.confにてice_connection_state_failed_timeoutで変更できますこのタイミングで
sora.jsonlにwarningとしてICE-CONNECTION-STATE-DISCONNECTEDが出力されます
状態が
failedに遷移した場合、Sora はクライアントの接続を切断しますこのタイミングで
sora.jsonlにerrorとしてICE-CONNECTION-STATE-FAILEDが出力されます
設定¶
ICE コネクションステート機能は無効にすることはできません。
ただし、切断や失敗までの判定時間を sora.conf にてデフォルト値から変更できます。
ice_connection_state_disconnected_timeout¶
この値は Sora が ICE コネクションステートを disconnected へと遷移する際にクライアントからの応答を待つ時間です。
デフォルトでは 5 s が設定されています。
詳細は _sora_conf-ice_connection_state_disconnected_timeout をご確認ください。
ice_connection_state_failed_timeout¶
この値は Sora が ICE コネクションステートを failed へと遷移する際にクライアントからの応答を待つ時間です。
デフォルトでは 10 s が設定されています。
詳細は _sora_conf-ice_connection_state_failed_timeout をご確認ください。
ウェブフック¶
コネクションの状態が checking と disconnected だった合計時間をイベントウェブフックで取得できます。
取得可能なイベントウェブフック
connection.createdconnection.updated``connection.destroyed ``
data.ice_connection_state.total_checking_duration_msにcheckingだった合計時間(ミリ秒)の合計が入りますdata.ice_connection_state.total_disconnected_duration_msにdisconnectedだった合計時間(ミリ秒)の合計が入ります
{
// 色々省略してます
"type": "connection.destroyed",
"channel_id": "sora",
"connection_id": "GS4Q8PQ5PS3EXC30T6PM2R7Y20",
"timestamp": "2023-08-16T05:42:13.970729Z",
"bundle_id": "GS4Q8PQ5PS3EXC30T6PM2R7Y20",
"client_id": "GS4Q8PQ5PS3EXC30T6PM2R7Y20",
"data": {
"ice_connection_state": {
"total_checking_duration_ms": 5002,
"total_disconnected_duration_ms": 10002
}
}
}
シーケンス図¶
重要
図のタイムアウト値はデフォルト値を採用しています。
connected¶
正常な接続状態である connected を継続しているシーケンス図です。
connected -> checking¶
正常な接続状態である connected から一時的に反応が無く checking 状態へ切り替わるシーケンス図です。
checking -> disconnected¶
一時的に反応が無い checking の状態が続いたため、 切断判断をするために短い間隔で疎通パケットを送信する disconnected 状態へ切り替わるシーケンス図です。
disconnected -> failed¶
切断判断をするため短い間隔で疎通パケットを送り続けたが、反応が無かったため failed へと切り替わるシーケンス図です。
disconnected -> checking -> connected¶
一定時間、不通になっていたため状態が disconnected になっていましたが、 checking を経て connected まで状態が戻るシーケンス図です。