Does WebRTC use TCP or UDP?
Asked Answered
C

1

106

I have some questions about WebRTC:

  1. Does WebRTC use TCP or UDP as its peer-to-peer transport? How can I know?
  2. I read that there are reliability mode and DTLS agreement, how does these affect?
  3. Is this transport the same for both Media and DataChannel?
  4. How do I switch between TCP and UDP?

I ask this because I know that browsers have a limit on the number of parallel connections (I think they talk over TCP), and maybe UDP connection is not limited.

Chitchat answered 19/9, 2013 at 14:48 Comment(0)
B
145
  1. It can use either. By default, preference is given to UDP, but depending on the firewall(s) in between the peers connecting it may only be able to connect with TCP. You can use Wireshark to capture packets and verify whether TCP or UDP is being used. In Chrome you can also see details on the selected candidate (googActiveConnection) by going to chrome://webrtc-internals.

  2. "Reliability mode" probably refers to the reliability mode of the DataChannel, which can be configured to run in reliable or unreliable mode. DTLS refers to the currently optional, but soon to be default method of exchanging encryption keys (the other deprecated mode is SDES). Firefox only supports DTLS, so for browser interop, you'll currently need to enable it in Chrome.

  3. The RTCPeerConnection (media) will use TCP or UDP, while the DataChannel uses SCTP. The SCTP implementation used by Firefox is implemented on top of UDP: https://code.google.com/p/sctp-refimpl/.

  4. It's possible to filter out TCP or UDP ICE candidates before adding them with addIceCandidate. Generally, you should not try to force the transport used since WebRTC will just "do the right thing". The browser does not limit the number of TCP connections used by WebRTC beyond any limit on the RTCPeerConnection or DataChannel (i.e., if you can have 10 PeerConnections, they can each use TCP without any problem).

Burlesque answered 19/9, 2013 at 16:24 Comment(4)
Great answer! From Chrome 31, SCTP is used by default for data channels.Juetta
@Any reason SCTP isn't used by audio/video? Isn't it effectively udp with "extras" (currently it's implemented on top of udp mostly)Efrenefron
For future users: in 1. chrome://webrtc-internals, you have to select "Read Stats From: Legacy"Psychological
The reason why I personally asked the question "does WebRTC use TCP or UDP" is to see if it were reliable or not. Point 3 says, Media will use TCP or UDP, but DataChannel will use SCTP, so DataChannel should be reliable, because SCTP is reliable (according to the SCTP RFC). This contradicts point 2., so if someone could clarify great!Draghound

© 2022 - 2024 — McMap. All rights reserved.