网易首页 > 网易号 > 正文 申请入驻

网络协议之:sctp流控制传输协议

0
分享至

简介

要讲网络协议,肯定离不开OSI(Open System Interconnection)的七层模型。我们一般关注的是网络层之上的几层,比如IPV4 IPV6所在的网络层,TCP UDP所在的传输层,HTTP FTP所在的应用层等。

今天要讲的sctp协议,全称是Stream Control Transmission Protocol,翻译成中文就是流控制传输协议。是由IETF在RFC 4960中提出的。

传输层已经有广泛被使用的TCP和UDP协议,那么为什么还要发明一个SCTP协议呢?

很明显SCTP协议是对TCP和UDP协议的提升,具体而言SCTP协议既提供了UDP协议的面向消息的特性,同时又具有TCP协议的可靠性、顺序传输和拥塞控制的功能,并且还提供了多宿主和冗余路径的功能,从而提高弹性和可靠性。

本文将会详细讲解SCTP的实现原理和协议详情。

TCP有什么不好

TCP有什么不好呢?TCP当然好,我们知道UDP是不可靠的消息传输方式,而TCP是可靠的消息传输方式。

UDP和TCP已经被应用在非常广泛的应用场景中。但是一个产品或者协议不可能十全十美,肯定会有一些缺点,我们来看看TCP的缺点有哪些。

TCP和UDP最大的不同是TCP是可靠的,也就是说TCP提供了通过 Internet 可靠地传输数据的方法。

但是TCP为了保证可靠的数据传输,对传输做了一些限制。

比如说,TCP为了保证数据传输的可靠性,需要严格要求数据传输的顺序。比如一个数据包被分拆成了三份分别标号为A,B,C。那么对于接收方来说,则必须先接受数据包A,然后是B和C。如果先接受到的B,那么接收方就会需要让发送发重发数据包。

在这种严格要求数据包顺序的情况下,可能会造成不必要的数据延迟和消息阻塞。

因为TCP是面向数据流的,为了标记数据流中的不同记录,TCP中的数据需要额外添加一些标记或者编码来对记录进行区分。

另外,为了提升传输效率,避免发送多个小数据包的情况,TCP还可能会对其进行优化,也就是说等等多个小的数据包将其合并为一个大的数据包。如果不希望这样的优化,那么需要在TCP数据包中设置PSH标志,明确该请求是无延迟的传输请求。

最后TCP还容易收到DOS(denial-of-service)攻击。

sctp的特点

既然TCP还有诸多的缺点,那么新的SCTP协议又有什么特点呢?

SCTP主要有两大特点,第一个特点就是Message-based,也就是说SCTP是面向消息的。SCTP传输的是一系列的消息,一个消息是一组字节。

相比之下TCP传输的是字节流。

SCTP中的一条消息可以拆分成为多个数据块,每个数据块中的所有数据都来自同一个用户。当这些数据需要在IP中进行传输的时候,SCTP会将这些数据包打包成为SCTP packets,每个SCTP packet,都包含一个packet header,如果需要的话还可以包含控制块,最后跟着的是数据块。

怎么理解TCP包和SCTP包的不同呢?

举个例子,当客户端以TCP协议向服务器端发送多条消息的时候,如果消息非常短,为了提升传输效率,TCP可能会将这些不同作用的小的数据放到同一个TCP包中。在服务器端接收的过程中也是一次收取这个TCP包中的所有数据,然后由应用程序本身来进行TCP包中底层数据的拆分。

对于SCTP包来说,一个SCTP包中可以包含多个data chunks,不同的data chunks可以包含不同用户的不同消息,因为SCTP包已经对不同的消息进行了区分,所以对于服务器端的读取来说就相对容易很多。

下面是一个SCTP包的基本结构:

从上图可以看出,前面的蓝色部分的12个字节是SCTP包的包头,其中前面的两个字节是源端口号,接着的两个字节是目标端口号,然后4个字节是验证标记,最后的4个直接是校验位,总共12个字节。

header后面就是data chunks,也就是数据块,每个chunk都包含一个类型位,flags位和长度位,后面跟着的是chunk的具体数据。

SCTP的另外一个特点就是multi-streaming,多流指的是SCTP能够并行传输多个独立的数据流,比如在访问网页的时候可以同时传输网页中的图像和网页的文本。

为什么可以这样操作呢?这也是由SCTP数据包的结构来决定的,我们可以看到SCTP的数据包中可以包含多个data chunks,这些data chunks可以包含不同的数据流过来的数据,所以面向消息的SCTP可以实现并行传输不同数据源数据的功能。

SCTP的另外一个特性就是Multihoming,Multihoming是multiple+homing的合成词,字面上的意思就是多个home。

这是什么意思呢?

我们知道对于TCP协议来说,客户端和服务器端都只有一个,属于一对一进行连接的情况,如果这个连接两端的而任何一个IP或者端口不可以,那么整个TCP的连接就崩溃了。

那么TCP可不可以发展为类似LSB负载均衡的模式呢?如果一个IP不可以,自动重连到备用的IP地址。

SCTP就是TCP协议的升级版本,它在增强可靠性方面做了优化。

具体而言,每个SCTP的节点都会使用心跳的机制定时检查远程节点的主IP地址和备用的冗余IP地址的可达性。在SCTP中一个节点可以绑定多个IP地址。

SCTP节点将会根据收到的远程节点的心跳返回值来确认具体的访问信息。

因为客户端节点和服务器端节点的个数可能是不同的,所以SCTP可以分为对称的multihoming和非对称的multihoming。

下面三个图分别是对称multihoming和两个非对称multihoming的情况:

最后,SCTP的安全性也有所提升。相较于TCP的三次握手相比,SCTP具有四次握手。

TCP的三次握手可能导致SYN攻击。

什么是SYN攻击呢?我们回顾一下TCP的三次握手流程,首先客户端发送一个SYN A请求给服务器端,服务器端在收到这个SYN请求之后,会将SYN请求缓存起来,然后向客户端返回SYN B,ACK A+1, 客户端在收到回复之后,校验ACK的值,然后再次发送ACK B+1到服务器端。服务器端收到B+1请求之后,最终确认客户端的身份,连接建立完成。

上面的流程中因为服务器端需要缓存TCP客户端的SYN消息,所以如果服务器收到大量SYN消息的话,就造成了SYN攻击。

相较而言,SCTP在收到客户端的连接请求之后,并不会立即分配内存缓存起来,而是返回一个COOKIE给客户端。客户端再次请求的时候,需要带上这个COOKIE信息,服务器端通过COOKIE校验,确认客户端的身份之后,才会最终建立连接。从而避免TCP的SYN攻击。

总结

综上所述,SCTP可以保证有序和无数数据流的可靠传输,可以支持Multihoming,每个节点都可以包含多个IP地址,从而实现冗余网络路径之间的透明故障转移。并提升了验证和确认机制,可以防止SYN攻击。

SCTP是一个非常优秀的协议。对于常用的操作系统而言,在特定的版本也提供了对SCTP的支持。比如在linux中,内核2.4版本之上都支持SCTP协议。

如果在windows或者MAC上,需要额外安装第三方驱动,其中windows的驱动叫做SctpDrv kernel driver,MAC上的驱动叫做SCTP Network Kernel Extension for Mac OS X。

本文已收录于 http://www.flydean.com/21-sctp/

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
扬尼斯去了迈阿密:凯尔特人怎么办?

扬尼斯去了迈阿密:凯尔特人怎么办?

张佳玮写字的地方
2026-06-23 13:56:35
中国男篮:杨瀚森低迷贺希宁8中1,核心后卫21+7,奇兵13分

中国男篮:杨瀚森低迷贺希宁8中1,核心后卫21+7,奇兵13分

体娱荒原
2026-06-23 21:27:12
盼到了!中国女排“王炸”组合复出倒计时

盼到了!中国女排“王炸”组合复出倒计时

林子说事
2026-06-23 19:37:00
斯卡洛尼赛后泼了盆冷水 阿根廷主帅赛后直言:冠军不靠“看好”

斯卡洛尼赛后泼了盆冷水 阿根廷主帅赛后直言:冠军不靠“看好”

隐于山海
2026-06-23 12:31:11
不撤案杀你全家,山西运城13岁女孩被强奸,不予立案后又调查了

不撤案杀你全家,山西运城13岁女孩被强奸,不予立案后又调查了

汉史趣闻
2026-06-23 08:23:52
是谁把红军逼上长征路?这位毒诸葛,异常聪明,却落得凄惨下场

是谁把红军逼上长征路?这位毒诸葛,异常聪明,却落得凄惨下场

史之铭
2026-06-20 01:36:48
毛剑卿:从专业角度讲,梅西踢得其实并不好,他本来至少能进4个

毛剑卿:从专业角度讲,梅西踢得其实并不好,他本来至少能进4个

风过乡
2026-06-23 13:29:36
中国女排两大强援即将归队!重返世界一流强队不是梦?

中国女排两大强援即将归队!重返世界一流强队不是梦?

云隐南山
2026-06-23 13:38:39
巴特洪堡站:王欣瑜2-0横扫费尔南德斯 第2次晋级草地赛八强

巴特洪堡站:王欣瑜2-0横扫费尔南德斯 第2次晋级草地赛八强

醉卧浮生
2026-06-23 20:38:59
“只有学渣家长会这样”,母亲在考场前失态,网友:你到底哭啥?

“只有学渣家长会这样”,母亲在考场前失态,网友:你到底哭啥?

泽泽先生
2026-06-22 19:49:50
凌晨1点CCTV5直播葡萄牙生死战!C罗冲击2纪录 不拿三分=基本出局

凌晨1点CCTV5直播葡萄牙生死战!C罗冲击2纪录 不拿三分=基本出局

麦子的篮球故事
2026-06-23 11:22:00
一只雌虎吃掉436人,创下吉尼斯纪录:真相就藏在它的牙齿里

一只雌虎吃掉436人,创下吉尼斯纪录:真相就藏在它的牙齿里

万物杂志
2026-06-23 06:04:44
遭官方曝光的“毒洗发水”,很多家庭还在用,难怪头发越来越少

遭官方曝光的“毒洗发水”,很多家庭还在用,难怪头发越来越少

健康之光
2026-06-22 12:55:25
医生:希望你的血脂报告里,永远不要出现这3项异常

医生:希望你的血脂报告里,永远不要出现这3项异常

华庭讲美食
2026-06-23 16:28:06
亚洲最穷国家:当地女性很开放,游客都是土豪,无不想去定居?

亚洲最穷国家:当地女性很开放,游客都是土豪,无不想去定居?

抽象派大师
2026-06-23 13:40:09
数百名医生已证实:维生素B12的真相,最好花点时间看看

数百名医生已证实:维生素B12的真相,最好花点时间看看

岐黄传人孙大夫
2026-06-19 18:45:03
降价也卖不动的合资燃油车开始主动撤出门店

降价也卖不动的合资燃油车开始主动撤出门店

界面新闻
2026-06-22 19:38:24
中国男篮险胜荷兰却喜忧参半,杨瀚森王俊杰与队友不在一个节拍

中国男篮险胜荷兰却喜忧参半,杨瀚森王俊杰与队友不在一个节拍

姜大叔侃球
2026-06-23 21:35:15
广西北流警方通报油罐车与水泥车碰撞致3死

广西北流警方通报油罐车与水泥车碰撞致3死

界面新闻
2026-06-23 11:32:30
韩国股市崩了!三星电子、SK海力士均创2008年以来最大跌幅|快讯

韩国股市崩了!三星电子、SK海力士均创2008年以来最大跌幅|快讯

华夏时报
2026-06-23 15:50:08
2026-06-23 22:11:00
flydean程序那些事
flydean程序那些事
最通俗的解读,最深刻的干货!
356文章数 438关注度
往期回顾 全部

科技要闻

48名中国开发者联名举报苹果

头条要闻

河南南阳曾47天查扣24辆冷链货车:拍卖350万上缴国库

头条要闻

河南南阳曾47天查扣24辆冷链货车:拍卖350万上缴国库

体育要闻

扬尼斯去了迈阿密:凯尔特人怎么办?

娱乐要闻

内娱95后顶流格局发生潜移默化的变化

财经要闻

屋顶光伏度苦夏

汽车要闻

施鹏泽:为什么奥迪E7X强调座舱气味安全?

态度原创

家居
本地
健康
游戏
公开课

家居要闻

绿意盎然 自然之境

本地新闻

吃一次广东龙舟饭,才懂什么是豪华盛宴

同样是中风,急救方向竟完全相反?

狂卖到脱销!Steam主机所有型号已在亚洲全部售罄

公开课

李玫瑾:为什么性格比能力更重要?

无障碍浏览 进入关怀版