dit Real-time Transport Protocol RTP

Anuncio
Real-time Transport
Protocol
RTP
Joaquín Salvachúa
jsr@dit.upm.es
-1-
© Joaquín Salvachúa 2004
dit
UPM
Problema con nuevos
servicios
u TCP servía para todo excepto:
4Envío de audio
4Envío de vídeo
4Envío de información en tiempo real.
u Enfoque adaptativo no es suficiente
-2-
© Joaquín Salvachúa 2004
dit
UPM
Necesidad de un protocolo
nuevo
u TCP necesita retransmisión
4Necesidad de vencimiento de temporizador
4Puede que la información retransmitida sea
demasiado antigua.
u UDP no tiene confirmación ni datos sobre el
contenido:
u No existe concepto de calidad de servicio
(QOS).
-3-
© Joaquín Salvachúa 2004
dit
UPM
Necesidad de dos
protocolos
u RTP
4Encapsulación de trafico en tiempo real
u RTCP
4Protocolo de reserva y garantía de calidad de
servicio a determinados flujos RTP.
u Necesidad de garantías en todo el recorrido.
u Parte de un esquema mayor a nivel global.
-4-
© Joaquín Salvachúa 2004
dit
UPM
Arquitectura
-5-
© Joaquín Salvachúa 2004
dit
UPM
Objetivos
u El protocolo No garantiza nada, solo ofrece
las facilidades necesarias para hacerlo.
u No esta asociado con ninguna aplicación
concreta.
u Necesidad de una descripción de :
4Perfil de tráfico.
4Formato de codificación.
-6-
© Joaquín Salvachúa 2004
dit
UPM
Objetivos
u Ligero: Implementación simple.
u Flexible: No indica algoritmos
u Neutral frente transporte
u Escalable: Unicast, multicast, broadcast
u Separación de datos y control
u Seguro: posibilidad de encriptación y
autenticación.
-7-
© Joaquín Salvachúa 2004
dit
UPM
Característica
u Datos:
4Temporización
4Detección de perdidas
4Etiquetado de contenidos
u Control
4Realimentación de QOS
4Estimación de miembros y detección de bucles.
-8-
© Joaquín Salvachúa 2004
dit
UPM
Funcionalidad
u Segmentación realizada por UDP ó IP
u Resecuenciación de paquetes.
u Detección de perdidas para estimación
posterior.
u Sincronización entre media
4Sincronización labios y control de retrasos
u Realimentación de QOS y Velocidad
u Identificación de la fuente.
-9-
© Joaquín Salvachúa 2004
dit
UPM
Posibles piezas
u Mezcladores
4Un flujo a partir de múltiples.
4Reduce el ancho de banda.
4Aparece como una nueva fuente.
u Traducciones
4Codificación de un solo media.
4Puede ser translación de protocolo (firewall)
4Cambio de codificación (ancho de banda).
- 10 -
© Joaquín Salvachúa 2004
dit
UPM
Cabecera RTP
u Payload type: Tipo de media contenido
u SSRC: indicación de sincronización
u sequence number: ++ para detectar perdidas.
u P: padding (for encryption)
u M: marker bit; Indica comienzo de frame para delay.
u CC: content source count (for mixers)
u CSRC: lista de identificadores en mezclas.
- 11 -
© Joaquín Salvachúa 2004
dit
UPM
Cabecera RTP
0
1
2
3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|V=2|P|X| CC
|M|
PT
|
sequence number
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
timestamp
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
synchronization source (SSRC) identifier
|
+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
|
contributing source (CSRC) identifiers
|
|
....
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
4 version (V)
4 padding (P)
4 extension (X)
- 12 -
CSRC count (CC)
marker (M)
payload type (PT)
© Joaquín Salvachúa 2004
dit
UPM
Temporización en RTP
u Incrementado en 1 por cada muestra
4 (ej., 160 for 20 ms packets @ 8000 Hz)
u Comienzo aleatorio
u Velocidad constante para el audio
4 (e.g., 8000 Hz for PCM-law, 44100 Hz for linear, 16-bit, 90
kHz for video)
u Múltiples imágenes de vídeo pueden tener el mismo
(en silencios).
- 13 -
© Joaquín Salvachúa 2004
dit
UPM
RTP en una red
u Típico : UDP, sin puerto fijo; RTCP port =
RTP port (par) + 1
u Típicamente el paquete de UDP esta
limitado a unos cientos de bytes (OS,
network, fragmentación)
u
u Necesidad de minimizar descarte y
congestón.
- 14 -
© Joaquín Salvachúa 2004
dit
UPM
RTCP ancho de banda
u Cada participante envia un paquete RTCP
para que se sepa quienes estan
escuchando.
u Ancho de banda de la sesión:
4Audio
4N * flujos de video.
- 15 -
© Joaquín Salvachúa 2004
dit
UPM
Sincronización entre flujos
u Necesidad de establecer sincronización
entre múltiples flujos (vídeo, audio,
transparencias).
u Necesidad de correlarlos tics con tiempo real
(depende de envío de temporizaciones
aleatorias).
u Correlarlas con la generación de muestras.
- 16 -
© Joaquín Salvachúa 2004
dit
UPM
RTP control protocol
u Paquetes almacenables (similares a datos).
4sender report (SR): bytes enviados y velocidad.
4 reports (RR): Jitter, Round-trip delay, perdidas.
4source description (SDES): nombre, email,
localización . . .
• CNAME (canonical name = user@host)
4explicit leave (BYE): para conocer quienes estan.
4extensions (APP): definidos por la aplicación (aún
ninguno)
- 17 -
© Joaquín Salvachúa 2004
dit
UPM
Referencias
RTP: A Transport Protocol for Real Time Applications
<http://www.ietf.org.internet-drafts/draft-ietf-avt-rtp-new02.txt>
RTP Profile for Audio and Video Conferences with Minimal
Control <http://www.ietf.org.internet-drafts/draft-ietf-avtprofile-new-04.txt>
The RTP specification is a product of the Audio Video
Transport (AVP) http://www.ietf.org/html.charters/avtcharter.html.
http://www.cs.columbia.edu/~hgs/rtp/faq.html
- 18 -
© Joaquín Salvachúa 2004
dit
UPM
Descargar