Protocolo de capa de transporte orientado a mensajes
En las redes de computadoras , el Protocolo de control de congestión de datagramas ( DCCP ) es un protocolo de capa de transporte orientado a mensajes . DCCP implementa una configuración confiable de conexión, desmontaje, notificación explícita de congestión (ECN), control de congestión y negociación de funciones. El IETF publicó DCCP como RFC 4340, un estándar propuesto , en marzo de 2006. RFC 4336 proporciona una introducción.
Operación
DCCP proporciona una manera de obtener acceso a mecanismos de control de congestión sin tener que implementarlos en la capa de aplicación . Permite una semántica basada en flujo como en el Protocolo de control de transmisión (TCP), pero no proporciona una entrega en orden confiable. La entrega secuenciada dentro de múltiples transmisiones como en el Protocolo de transmisión de control de transmisión (SCTP) no está disponible en DCCP. Una conexión DCCP contiene tráfico de confirmación y tráfico de datos. Los acuses de recibo informan al remitente si sus paquetes han llegado y si fueron marcados por Notificación de congestión explícita (ECN). Los acuses de recibo se transmiten de manera tan confiable como lo requiera el mecanismo de control de congestión en uso, posiblemente de manera completamente confiable.
DCCP tiene la opción de números de secuencia muy largos (48 bits) correspondientes a un ID de paquete, en lugar de un ID de byte como en TCP. La gran longitud de los números de secuencia pretende proteger contra "algunos ataques ciegos, como la inyección de DCCP-Resets en la conexión". [1]
Aplicaciones
DCCP es útil para aplicaciones con limitaciones de tiempo en la entrega de datos. Dichas aplicaciones incluyen transmisión de medios , juegos multijugador en línea y telefonía por Internet . En dichas aplicaciones, los mensajes antiguos rápidamente se vuelven inútiles, por lo que es preferible recibir mensajes nuevos que reenviar mensajes perdidos. A partir de 2017, [update]estas aplicaciones a menudo se conformaron con TCP o utilizaron el Protocolo de datagramas de usuario (UDP) e implementaron sus propios mecanismos de control de congestión, o no tienen ningún control de congestión. Si bien es útil para estas aplicaciones, DCCP también puede servir como mecanismo general de control de congestión para aplicaciones basadas en UDP, agregando, según sea necesario, mecanismos para una entrega confiable o en orden además de UDP/DCCP. En este contexto, DCCP permite el uso de mecanismos de control de congestión diferentes, pero generalmente compatibles con TCP .
Implementaciones
Los siguientes sistemas operativos implementan DCCP:
- FreeBSD , versión 5.1 [2] como parche
- Linux desde la versión 2.6.14, [3] pero marcado como obsoleto desde la versión 6.4 debido a la falta de mantenimiento y su eliminación programada para 2025. [4]
Biblioteca de espacio de usuario:
- DCCP-TP Archivado el 23 de julio de 2008 en Wayback Machine, la implementación está optimizada para la portabilidad, pero no ha tenido cambios desde junio de 2008. [5]
- El propósito de GoDCCP de esta implementación es proporcionar un marco estandarizado y portátil compatible con NAT para comunicaciones entre pares con control de congestión flexible, según la aplicación.
Estructura del paquete
El encabezado genérico DCCP adopta diferentes formas según el valor de X, el bit de números de secuencia extendidos. Si X es uno, el campo Número de secuencia tiene una longitud de 48 bits y el encabezado genérico ocupa 16 bytes, como se muestra a continuación.
Si X es cero, sólo se transmiten los 24 bits bajos del número de secuencia y el encabezado genérico tiene 12 bytes de longitud.
- Puerto de origen (16 bits)
- Identifica el puerto de envío
- Puerto de destino (16 bits)
- Identifica el puerto de recepción
- Compensación de datos
- (8 bits): el desplazamiento desde el inicio del encabezado DCCP del paquete hasta el inicio de su área de datos de aplicación, en palabras de 32 bits.
- CCVal (4 bits)
- Utilizado por el CCID de HC-Sender
- Cobertura de suma de comprobación (CsCov) (4 bits)
- La cobertura de suma de verificación determina las partes del paquete que están cubiertas por el campo Suma de verificación.
- Suma de comprobación (16 bits)
- La suma de comprobación de Internet del encabezado DCCP del paquete (incluidas las opciones), un pseudoencabezado de capa de red y, según la cobertura de la suma de comprobación, todos, algunos o ninguno de los datos de la aplicación.
- Reservado (Res) (3 bits)
- Los remitentes DEBEN establecer este campo en todos los ceros en los paquetes generados y los receptores DEBEN ignorar su valor.
- Tipo (4 bits)
- El campo Tipo especifica el tipo de paquete.
- Números de secuencia extendidos (X) (1 bit)
- Establezca en uno para indicar el uso de un encabezado genérico extendido con números de secuencia y acuse de recibo de 48 bits.
- Número de secuencia (48 o 24 bits)
- Identifica el paquete de forma única en la secuencia de todos los paquetes que la fuente envió en esta conexión
El desarrollo actual
De manera similar a la extensión del protocolo TCP mediante la capacidad de rutas múltiples ( MPTCP ), también para DCCP la característica de rutas múltiples está bajo discusión en el IETF [6], correspondientemente denominada MP-DCCP. Las primeras implementaciones ya se han desarrollado, probado y presentado en un enfoque colaborativo entre operadores y académicos [7] y están disponibles como una solución de código abierto.
Ver también
Referencias
- ^ RFC 4340 sección 7.6
- ^ "[dccp] Implementación de FreeBSD". www.ietf.org . Consultado el 18 de abril de 2018 .
- ^ "Linux obtiene DCCP [LWN.net]". lwn.net . Consultado el 18 de abril de 2018 .
- ^ "dccp: aviso de obsolescencia de impresión". kernel.org .
- ^ "Registro de cambios para la wiki dccp-tp, consultado el 13 de junio de 2011". Archivado desde el original el 4 de octubre de 2011 . Consultado el 13 de junio de 2011 .
- ^ Enmienda, Markus; Brunström, Anna; Kassler, Aneas; Rakocevic, Veselin; Johnson, Stephen (9 de noviembre de 2021). "Extensiones DCCP para operación de rutas múltiples con múltiples direcciones".
- ^ "Extensión de rutas múltiples para DCCP".
enlaces externos
- Carta del Protocolo de control de congestión de datagramas (dccp) del IETF
Especificaciones del protocolo
- RFC 4340: Protocolo de control de congestión de datagramas
- RFC 5595: códigos de servicio del Protocolo de control de congestión de datagramas (DCCP)
- RFC 5596: técnica de apertura simultánea de DCCP para facilitar el recorrido NAT/Middlebox
- RFC 5762: RTP y DCCP
- RFC 5238: Seguridad de la capa de transporte de datagramas (DTLS) sobre DCCP
- RFC 5634: Inicio rápido para DCCP
- RFC 6773: encapsulación UDP del protocolo de control de congestión de datagramas para cruce NAT
ID de control de congestión
- RFC 4341: Perfil para el control de congestión DCCP ID 2: control de congestión similar a TCP
- RFC 4342: Perfil para el control de congestión DCCP ID 3: Control de velocidad compatible con TCP (TFRC)
- RFC 5622: Perfil para el control de congestión DCCP ID 4: Control de velocidad compatible con TCP para paquetes pequeños (TFRC-SP)
Otra información
- RFC 4336: Declaración del problema para el protocolo de control de congestión de datagramas (DCCP)
- Página de DCCP de uno de los autores de DCCP
- Soporte DCCP en Linux
- Protocolo de control de congestión de datagramas (DCCP)