Qual servidor lida com a troca de ICE (troca de nós por rotas potenciais entre pares), servidor de sinalização SDP ou servidor STUN (ou TURN, que também pode funcionar como STUN)?
A conectividade MDN WebRTC mostra que o SDP Signaling Server lida com o ICE Exchange.
Entretanto, o WebRTC.org Getting started with peer connections diz que o STUN ou TURN Server lida com a troca ICE.
Como as condições da rede podem variar dependendo de uma série de fatores, um serviço externo é geralmente usado para descobrir os possíveis candidatos para conexão a um peer. Esse serviço é chamado ICE e usa um servidor STUN ou TURN.
RFC8445 - Estabelecimento de Conectividade Interativa (ICE) também indica que é STUN ou TURN para fazer troca de ICE.
2.1. Reunindo Candidatos
Para executar o ICE, um agente ICE identifica e reúne um ou mais candidatos de endereço. Um candidato tem um endereço de transporte -- uma combinação de endereço IP e porta para um protocolo de transporte específico (com apenas UDP especificado aqui). Existem diferentes tipos de candidatos; alguns são derivados de interfaces de rede físicas ou lógicas, e outros são detectáveis via STUN e TURN.
A primeira categoria de candidatos são aqueles com um endereço de transporte obtido diretamente de uma interface local. Tal candidato é chamado de "candidato host". A interface local pode ser Ethernet ou Wi-Fi, ou pode ser uma obtida por meio de um mecanismo de túnel, como uma Rede Privada Virtual (VPN) ou IP Móvel (MIP). Em todos os casos, tal interface de rede aparece para o agente como uma interface local da qual portas (e, portanto, candidatos) podem ser alocados.
Em seguida, o agente usa STUN ou TURN para obter candidatos adicionais.
Há uma diferença entre obter candidatos ICE e trocar candidatos ICE. Os servidores STUN/TURN são usados para obter candidatos. Um candidato é um caminho de rede potencial que ambos os pares podem usar para falar um com o outro. Cada par descobre quais caminhos potenciais eles estão vendo. Então eles trocam esses candidatos e concordam com o melhor que ambos compartilham.
O servidor STUN é apenas um auxiliar que auxilia a abrir buracos em firewalls e descobrir IPs/portas.
O servidor TURN é um relé, um caminho potencial em si mesmo.
O servidor de sinalização é o usado para realmente trocar esses candidatos descobertos entre os dois pares.
Depois que a troca ocorre e eles concordam com um par candidato, a comunicação por um desses pares IP/porta começa a acontecer.