Linux网络协议之:数据报拥塞控制协议(DCCP)

【推荐阅读】

浅谈linux 内核网络 sk_buff 之克隆与复制

深入linux内核架构--进程&线程

了解Docker 依赖的linux内核技术

数据报拥塞控制协议( DCCP )是一种面向信息的传输层协议。 DCCP提供双向单播连接的拥塞控制不可靠数据报。DCCP实施可靠的连接建立,拆卸, ECN,拥塞控制,和功能协商。 DCCP是适合传输大量数据的应用程序,其能从及时性和可靠性之间的权衡取舍中受益。

DCCP提供了一种不必在应用程序层执行的拥塞控制机制。它考虑到基于流的语法,就像在TCP中的一样 ,但并不提供可靠的顺序递送。在多种机制中的顺序递送例如在SCTP协议中在DCCP中并不可用。

DCCP在递送数据时对有时间限制的应用程序是有用的,但是如果可靠的顺序递送与拥塞避免相结合可能对接收器来说变得没有用处。这样的应用程序有可能包括流媒体和网络电话。这类应用程序或者满足TCP或使用UDP和实施它们自己的拥塞控制机制(或根本没有拥塞控制)。

一个 DCCP连接包含被确认流量以及数据流量。确认告诉发件人它的数据包已抵达,以及他们是否是ECN标准的。Acks和在使用要求中的拥塞控制机制一样被可靠传输,或许是完全可靠的。

DCCP有一个非常长的( 48位)序列号与一个数据包ID相匹配的选项(而不是像在 TCP中的一个字节的ID ) 。这个长的序列号码的用意是防止“有些盲目的攻击,如DCCP -重置的注入到连接中。

协议结构

数据报拥塞控制协议的题头是:

来源地和目的地端口:16位。这些区域的确定连接,类似的在TCP和UDP 中的相应区域。

数据偏移:8位。这个偏移从一开始的数据包的DCCP标题开始到应用数据区域的标题,共32位字符。

CCVal :4位。被HC -发件人CCID使用。

校验范围( CsCov):4位。校验范围决定了这个数据包被校验区域所所涵盖的部分。

校验和:16位。在数据包的DCCP标题(包括选项)的因特网校验和 ,一个网络层虚假标题 ,依赖于校验和,全部,一些,或没有应用数据。

保留的(Res):3位。寄件人必须设置这一区域生成的数据包全部为零,接收器必须忽略它的值。

类型:4位。这一类型的字段指定数据包的类型。下列值被定义:

延长的序列号(X):1位。设置为1表明扩展通用头与48位序列和确认号码的使用。

序号:48或24位。标识这个数据包在所有数据包的序列中是独特的,发起这个连接的源头。

每发送一个数据包序列号加1,包括像DCCP-Ack这样没有携带任何应用数据的数据包。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值