Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
2016.8時点WebRTCの標準化動向からいくつか / WebRTC Standards ...
Search
iwashi
November 27, 2022
Technology
0
240
2016.8時点 WebRTCの標準化動向からいくつか / WebRTC Standards trends at 2016.8
WebRTC Meetup Tokyo #11 での発表資料です。
動画は↓にあります
https://youtu.be/0RYWw1nPxio?t=1h27m51s
iwashi
November 27, 2022
Tweet
Share
More Decks by iwashi
See All by iwashi
AIはプロダクト開発をどう変えたか?〜 3つの役割から見る「変化」と「未来」〜 / How AI Transformed Product Development: A Look at "Change" and "Future" via Three Roles
iwashi86
3
1.1k
ざっくり学ぶ 『エンジニアリングリーダー 技術組織を育てるリーダーシップと セルフマネジメント』 / 50 minute Engineering Leader
iwashi86
12
6.5k
最高のステークホルダーになるために / Striving to be the best stakeholder
iwashi86
11
4.6k
n=1の経験が紡ぐエンジニアリングマネジメントの可能性 / The Possibilities of Engineering Management from n=1 Experiences
iwashi86
23
15k
エンジニアリングが好きな私たちのためのエンジニアリングマネジャー入門 / Engineering management for the rest of us
iwashi86
25
6.1k
エレガントパズル 30分 ダイジェスト版/ Elegant Puzzle 30min Digest
iwashi86
6
730
エレガントパズル エンジニアのマネジメントという難問にあなたはどう立ち向かうのか / Elegant Puzzle
iwashi86
18
5k
ベロシティを高く保つ仕事のすすめ方 / Maintaining a High Velocity as Productivity Hacks
iwashi86
54
22k
マネージャー&リーダー向け 社内トレーニング / Training of management and leadership for Stockmark
iwashi86
64
33k
Other Decks in Technology
See All in Technology
Bill One急成長の舞台裏 開発組織が直面した失敗と教訓
sansantech
PRO
2
390
小さく始めるBCP ― 多プロダクト環境で始める最初の一歩
kekke_n
1
470
ランサムウェア対策としてのpnpm導入のススメ
ishikawa_satoru
0
210
顧客の言葉を、そのまま信じない勇気
yamatai1212
1
360
ブロックテーマ、WordPress でウェブサイトをつくるということ / 2026.02.07 Gifu WordPress Meetup
torounit
0
190
Oracle Cloud Observability and Management Platform - OCI 運用監視サービス概要 -
oracle4engineer
PRO
2
14k
Oracle AI Database移行・アップグレード勉強会 - RAT活用編
oracle4engineer
PRO
0
100
超初心者からでも大丈夫!オープンソース半導体の楽しみ方〜今こそ!オレオレチップをつくろう〜
keropiyo
0
120
StrandsとNeptuneを使ってナレッジグラフを構築する
yakumo
1
120
Bedrock PolicyでAmazon Bedrock Guardrails利用を強制してみた
yuu551
0
250
2026年、サーバーレスの現在地 -「制約と戦う技術」から「当たり前の実行基盤」へ- /serverless2026
slsops
2
260
プロダクト成長を支える開発基盤とスケールに伴う課題
yuu26
4
1.4k
Featured
See All Featured
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
120
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
320
How to make the Groovebox
asonas
2
1.9k
Highjacked: Video Game Concept Design
rkendrick25
PRO
1
290
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
260
Fireside Chat
paigeccino
41
3.8k
Believing is Seeing
oripsolob
1
57
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2k
GitHub's CSS Performance
jonrohan
1032
470k
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
Ethics towards AI in product and experience design
skipperchong
2
200
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
120
Transcript
2016/8月時点 WebRTCの標準化動向からいくつか 2016/8/8(Mon) @ WebRTC Meetup Tokyo #11 @iwashi86
▪名前 @iwashi86 ▪仕事 SkyWayの開発・運用
WebRTCの標準化団体
役割の違い ネットワークを流れる プロトコル側を規定 ブラウザのAPI側を規定
Changes since May 13, 2016 Changes since February 15, 2016
Changes since November 23, 2015 進化スピードが速い
正しい技術記事 無くなる問題! 英語も古い記事が多いので注意
None
圧倒的感謝
【本LTの内容】 現在の最新実装ではなく、 将来どうなっていくか、という仕様を紹介 (個人的に開発者へ影響がありそうな仕様をピックアップ) 【本LTのゴール】 WebRTCの未来を知っていること
先に注意 W3C仕様は、ブラウザに実装されてないものが多いので、 `undefined` が出ても泣かないこと!
本題
まずW3C側から
RTCRtpTranceiver ・MediaStreamTrackの送受信をコントロール RTCRtpSender RTCRtpReceiver ・Chrome/Firefox共に未実装 = RTCPeerConnection.getTransceivers() は undefined ・Firefoxは、
getSenders() / getReceivers() が存在
RTCRtpTranceiver.setDirection ・setDirection(“方向属性”) で、メディアの送受信方向・非活性を設定可能 ・方向属性に設定できるもの ・sendrecv ・sendonly ・recvonly ・inactive ・今同じことする場合 ⇒
RTCRtpTranceiver.setCodecPreference ・setCodecPreference(“codec名”) で、コーデックの優先順序を設定可能 ・今同じことをする場合は、 createOffer/Answerで作成したSDPを修正
RTCRtpTranceiver.setCodecPreference ・setCodecPreference(“codec名”) で、コーデックの優先順序を設定可能 ・今同じことをする場合は、 createOffer/Answerで作成したSDPを修正 ・Tips:VP8やめたいとき ・正しいのは関連するVP8の記述を削除 ・ハックなのは、VP8をhogeなどに置換。 結果として、ネゴシエーションで合意取れず、 他のコーデックが選択される
RTCRtpSender.setParameter ・setParameter(RTCRtpParameters) で、コーデックのオプションやRTCPの扱いを設定 ・できることの例 ・maxBitrateを設定 ・解像度を優先するか、フレームレートを優先するか選択 ・maintain-framerate ・maintain-resolution ・balanced ・ちなみに、RIDというsimulcast向けのヘッダ設定もこれ
IETFの話
IETF96 (2016/7実施) は省略 ・IETF96の議論内容はニッチすぎて、 本Meetupでは有用なものが少ないと判断 ・ニッチな例 (rtcweb WGより) ・max-bundleが指定されたにも関わらず エンドポイントがbundleしてないメディアを
送ってきたらどう振る舞うべきか? ⇒結論:最初のm-lineを採用して残りはreject
代わりに面白そうな仕様を2つ 1. Mobility with TURN (TRAM WGより) (draft-ietf-tram-turn-mobility-03) 2. ICE
Network Cost (ICE WGへの個人ドラフト) (draft-thatcher-ice-network-cost-00)
代わりに面白そうな仕様を2つ 1. Mobility with TURN (draft-ietf-tram-turn-mobility-03) 2. ICE Network Cost
(draft-thatcher-ice-network-cost-00)
Mobility with TURN で解決したいこと • モバイルで移動中にIPが変わることがある • 例: 会社から外出 Wifi(TURN)
-> LTE • このときの現在のWebRTCの動作 ⇒ 一度、切断して再接続 • しかも変更後もTURN経由になった場合※は • Allocation Request • Create Permission • SDP再度交換 (ICE候補の交換) • ICEでホールパンチング というめんどくさい手順を踏まないといけない ※ 日本は代表キャリアがP2Pを通すので比較的レア
Mobility with TURN の解決方法
Mobility with TURN の解決方法 この部分は IPを変更しない (PeerAから見える IPは同じ。TURNが 変更を吸収する。)
代わりに面白そうな仕様を2つ 1. Mobility with TURN (draft-ietf-tram-turn-mobility-03) 2. ICE Network Cost
(draft-thatcher-ice-network-cost-00)
ICE Network Cost で解決したいこと • ICEで候補を集めた結果、以下の経路候補ができた 1. Wifi <-> Wifi
2. Wifi <-> LTE 3. LTE <-> Wifi 4. LTE <-> LTE • このとき、どれを選べばいいのか?
ICE Network Cost で解決したいこと • ICEで候補を集めた結果、以下の経路候補ができた 1. Wifi <-> Wifi
2. Wifi <-> LTE 3. LTE <-> Wifi 4. LTE <-> LTE • このとき、どれを選べばいいのか? • 日本での通信事情・金銭面を考えると もちろん[1]の Wifi <-> Wifi が望ましい • しかし、仮に重要通信で金銭面を考慮しなくて良い &Wifiが混雑していてLTEのが通信品質が良いなら?
ICE Network Cost で解決方法 • ICEの候補情報にネットワークコストを付与 つまり: a=candidate …(略)...
network-id=1 network-cost=50 • 経路は、ネットワークコストを加味して選定 • ICE Priorityも考慮要素 • ネットワークコストの算出ロジックは実装依存
まとめ • W3C: • RTCRtpTranceiver/Sender の中から setDirection()、setCodecPreference() を紹介 • IETF:
• Mobility with TURN • ICE Network Cost
(時間あれば)参考として • IETFは、誰でも参加できます • IETF97は11月でソウル • オンラインで良いなら無料 • IETF96の議論模様は Youtube
で公開 https://www.youtube.com/channel/UC8dtK9njBLdFnBahHFp0eZQ • 標準化というと堅苦しそうですが、 どのようにしてRFCが制定されていくのか、 一度、様子を覗いてみてはいかがでしょうか? • なおW3Cは、会員(有償)じゃないと参加困難…