chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

讓“可靠”變得“更快更安全”的數(shù)據(jù)傳輸協(xié)議:SCTP

中興文檔 ? 來源:中興文檔 ? 2023-12-28 17:25 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

粉絲點名要看的文章,這就來咯!

在《靈魂拷問:TCP&UDP徹底搞懂了嗎?》里,文檔君和大家一起學習到了TCP和UDP這2種協(xié)議的區(qū)別和工作原理。

TCP和UDP的優(yōu)點和缺點都很明顯,總之是:各有千秋、旗鼓相當、難分軒輊、互有短長。

聰明的粉絲是善于思考和發(fā)問的:有沒有一種協(xié)議,可以將TCP和UDP的優(yōu)點集于一身?

ffcdd8ce-a559-11ee-8b88-92fbcf53809c.png

來吧,今天文檔君就和大家一起了解一下SCTP,解答各位粉絲的疑問吧!

Part1什么是SCTP?

SCTP(Stream Control Transmission Protocol,流控傳輸協(xié)議)的出現(xiàn),并不是萬丈高樓平地起,而是站在TCP這個巨人肩膀上,讓數(shù)據(jù)傳輸從“可靠”變得“更快更安全”。

假設有2個主機(Host)之間想要通過IP通信,SCTP在TCP的基礎(chǔ)上,進行了下面的一系列改造:

ffdcf002-a559-11ee-8b88-92fbcf53809c.png

端點端點位于主機上,是一個邏輯實體。簡單來說,2個主機之間進行數(shù)據(jù)傳輸?shù)脑?,端點可以看作是“起點”和“終點”。 1個主機可以有多個IP地址和多個開放端口,IP地址+端口號的組合,稱為傳送地址。 一個傳送地址,例如:100.100.10.1:1000,可以唯一標識一個端點。一個端點,可以擁有多個不同的傳送地址。例如:端點A可以使用的傳送地址包括100.100.10.1:1000、100.100.10.2:1000、100.100.10.1:1001。端點B可以使用的傳送地址包括200.200.20.1:2000、200.200.20.2:2000。那么端點A可以使用傳送地址100.100.10.1:1000、100.100.10.2:1000,與端點B進行數(shù)據(jù)傳輸。 細心的粉絲應該也發(fā)現(xiàn)了,對于同1個目的端點,起始端點的多個傳送地址之間,端口號可以相同,IP地址必須不相同。 如果將網(wǎng)絡世界比作是海洋,主機可以看做是港口,端點就是港口中專營數(shù)據(jù)進出口的商家,傳送地址就是港口中的一個個碼頭,海量的數(shù)據(jù)通過碼頭完成了裝載出發(fā)和到達卸載。偶聯(lián)(Association)2個端點之間,通過四步握手機制建立的邏輯聯(lián)系或者通道,叫做偶聯(lián)。 SCTP規(guī)定:在任何時刻的2個端點之間,最多只能建立1個偶聯(lián)。 港口A中的本端端點(商家A),要想與港口B中的對端端點(商家B)進行數(shù)據(jù)傳輸,必須握手四次,成功達成共識,相當于簽訂了一個進行數(shù)據(jù)傳輸?shù)暮贤?只有成功建立偶聯(lián)(簽訂合同)后,2個端點之間才可以進行數(shù)據(jù)的傳輸。

流(Stream)

流是SCTP協(xié)議中的一個特殊術(shù)語,主要用來指明數(shù)據(jù)的序列:1個流中包含了多個消息,而且消息之間是有先后順序的。

在1個偶聯(lián)中,包含了多個流,每個流,都是從1個端點到另外1個端點的單向邏輯通道。

每個流都有自己專屬的流ID,不同流之間是相互獨立的,每個流可以單獨發(fā)送數(shù)據(jù)而不受其他流的影響。

數(shù)據(jù)是如何從一個碼頭傳輸?shù)搅硗庖粋€碼頭的?

TCP和SCTP各有自己的方式:SCTP采用了流,流中的數(shù)據(jù)是以塊為基本單位;TCP采用了包,包中的數(shù)據(jù)以字節(jié)為基本單位。

相當于TCP在傳輸數(shù)據(jù)的時候,一艘貨船上只裝載1件貨物。而STCP在傳輸數(shù)據(jù)的時候,將多件貨物打包成集裝箱,一艘貨船上可以裝載N多個集裝箱,而且集裝箱之間是有編號的,是順序排列的。

通路(Path)通路是在一個偶聯(lián)中,數(shù)據(jù)在傳輸過程中所經(jīng)過的路徑。這個路徑,是可以多條的。通路的數(shù)量,取決于一個偶聯(lián)中的起始端點、目的端點中使用的傳送地址的數(shù)量。 簡單來說,本端端點(商家A)擁有2個碼頭,對端端點(商家B)也擁有2個碼頭,那數(shù)據(jù)要裝船啟航,就有4條不同的航線可以選擇。

Path0:本端傳送地址1(100.100.10.1:1000)發(fā)送SCTP分組到對端傳送地 址1(200.200.20.1:2000)。

Path1:本端傳送地址2(100.100.10.2:1000)發(fā)送SCTP分組到對端傳送地 址1(200.200.20.1:2000)。

Path2:本端傳送地址1(100.100.10.1:1000)發(fā)送SCTP分組到對端傳送地 址2(200.200.20.2:2000)。

Path3:本端傳送地址2(100.100.10.2:1000)發(fā)送SCTP分組到對端傳送地 址2(200.200.20.2:2000)。

一般情況下,兩個端點之間會選擇一條航線,作為首選通路。一旦首選通路出現(xiàn)故障,SCTP可以將航線自動切換到其他備用的通路上。 Part2SCTP如何加快數(shù)據(jù)傳輸? 在上述改進的基礎(chǔ)上,SCTP的數(shù)據(jù)傳輸效率有了飛躍。 SCTP的基本工作步驟如下:

建立偶聯(lián):握手四次,成功達成共識。

打開數(shù)據(jù)流:在建立偶聯(lián)后,發(fā)送OPEN消息來打開1個新的數(shù)據(jù)流。OPEN消息中包含了流的ID、優(yōu)先級和其他參數(shù)。

發(fā)送數(shù)據(jù):一旦數(shù)據(jù)流打開,就可以在這個流上發(fā)送數(shù)據(jù),通過發(fā)送USER消息來完成。USER消息中包含了流ID和要發(fā)送的數(shù)據(jù)。

關(guān)閉數(shù)據(jù)流:數(shù)據(jù)都已經(jīng)傳輸完畢,發(fā)送1個CLOSE消息來關(guān)閉數(shù)據(jù)流。CLOSE消息中包含了流ID和其他參數(shù)。

關(guān)閉偶聯(lián):發(fā)送1個SHUTDOWN消息來關(guān)閉偶聯(lián)。SHUTDOWN消息中包含了關(guān)閉連接的原因和其他參數(shù)。

在發(fā)送數(shù)據(jù)的環(huán)節(jié)上,SCTP擁有一些獨特的辦法:

首先,SCTP是面向消息的傳輸,將上層應用傳遞下來的用戶數(shù)據(jù)以消息的形式傳輸,SCTP提供消息的拆分、綁定、重組功能。在傳輸側(cè),將用戶數(shù)據(jù)裝入一個集裝箱,這個集裝箱叫做SCTP分組。 每個SCTP分組包括一個公共頭和多個塊,塊分為控制塊和數(shù)據(jù)塊,控制塊用于SCTP的連接控制,包括連接的建立、關(guān)閉、傳輸路徑的維護等;數(shù)據(jù)塊包含了應用層的用戶數(shù)據(jù)。

000ac838-a55a-11ee-8b88-92fbcf53809c.png

而且如果某個用戶數(shù)據(jù)的長度很短,裝在一個集裝箱內(nèi)會很浪費空間。SCTP可以將多個用戶數(shù)據(jù)綁定在一起,裝在同一個集裝箱的數(shù)據(jù)塊中,大大提高了利用率。在接收側(cè),SCTP將一個集裝箱的內(nèi)用戶數(shù)據(jù),重新組裝成完整的用戶數(shù)據(jù),傳遞給上層應用。

其次,SCTP支持多路復用,即允許在1個偶聯(lián)中發(fā)送多個流。每個流,都是一艘艘裝載滿數(shù)據(jù)的貨船,每個貨船都有自己獨特的ID,相互之間互不影響。

001e7086-a55a-11ee-8b88-92fbcf53809c.png

Part3SCTP如何讓數(shù)據(jù)傳輸更安全? SCTP在以下幾個方面,對數(shù)據(jù)傳輸?shù)陌踩?、穩(wěn)定性進行了有效的保障。只是因為建立連接時,多握了一次手

0022c4d8-a55a-11ee-8b88-92fbcf53809c.png

SCTP的四次握手流程如下:

本端端點(商家A)發(fā)送INIT消息到對端端點(商家B),向?qū)Χ硕它c(商家B)通知本端端點(商家A)的接收窗口大小、地址列表、初始標記及發(fā)送的第一個DATA包的發(fā)送序號。

對端端點(商家B)收到INIT消息后,回送INIT ACK消息給本端端點。INIT ACK消息中除了攜帶著與INIT消息相同的自己的連接信息外,還攜帶有狀態(tài)的COOKIE信息。

本端端點(商家A)收到INIT ACK消息后。利用消息中的STATE COOKIE生成COOKIE ECHO消息,將COOKIE ECHO消息發(fā)到對端端點(商家B),告訴對端端點(商家B)已收到消息。

對端端點(商家B)在收到合法的COOKIE ECHO后,開始進行創(chuàng)建連接TCB(傳輸控制塊)和申請資源的工作,發(fā)送COOKIE ACK消息給本端端點,并進入ESTABLISH狀態(tài)。對端端點(商家B)在收到COOKIE ACK后,狀態(tài)變?yōu)镋STABLISH,至此完成連接建立工作。

與TCP的三次握手流程對比,SCTP在第2步和第3步中使用了COOKIE ECHO和INIT ACK消息,這2個消息都包含了對端端點(商家B)的參數(shù)信息和Cookie值。 這些參數(shù)信息和Cookie值用于驗證對端端點(商家B)的身份,保證連接的安全性。還因為在傳輸數(shù)據(jù)時,多了身份的認證。SCTP提供了無差錯的傳輸服務,靠的是在集裝箱公共分組頭里面,包含了一個驗證標簽(VerificATIon Tag)和一個可選的32位校驗碼(Checksum)。

驗證標簽的值,在建立偶聯(lián)(簽訂合同)時,由本端端點(商家A)和對端端點(商家B)共同設置的。 如果收到的集裝箱公共分組頭中如果沒有期望的驗證標簽值,對端端點(商家B)會認為這個集裝箱是危險的或者無效的,將丟棄這個集裝箱。

集裝箱中的校驗碼,是通過ADLER-32算法在數(shù)據(jù)塊的基礎(chǔ)上計算出來的32位字符串。本端端點(商家A)把計算后的校驗碼放在集裝箱中,是為了給數(shù)據(jù)塊的一個額外保護,用來避免由網(wǎng)絡造成的數(shù)據(jù)差錯。 對端端點(商家B)收到集裝箱,也通過ADLER-32算法在數(shù)據(jù)塊基礎(chǔ)上計算出來1個校驗碼,如果和集裝箱里已有的32位校驗碼一致,說明數(shù)據(jù)塊是沒有差錯的。 如果兩個校驗碼不一致,說明數(shù)據(jù)塊出錯了,對端端點(商家B)也會丟棄這個集裝箱。

002a8a06-a55a-11ee-8b88-92fbcf53809c.png

也因為在通路空閑時,多了心跳的檢測。

SCTP通過心跳檢測功能,定期檢查連接的健康狀況,從而及時發(fā)現(xiàn)和修復連接問題。

當某條通路空閑時,本端端點(商家A)會要求SCTP生成相應的心跳消息,并通過該通路發(fā)送到對端端點(商家B),而對端端點(商家B)必須立即發(fā)回對應的心跳確認消息。

通過這樣的方式,SCTP精確測量回路時延RTT(Round Trip Time),達到監(jiān)控偶聯(lián)的可用情況和保持SCTP 偶聯(lián)的激活狀態(tài)的目的。

Part4SCTP的發(fā)展趨勢如何?

前面講過,SCTP是在TCP的基礎(chǔ)上進行了一些改進。

這是因為TCP在處理多媒體應用時,存在擁塞控制問題和可靠傳輸問題。

所以早在1990年代中期,人們就開始研究SCTP協(xié)議,并先后發(fā)布了多個版本。

每個新版本,都是對前一個版本的改進,并在2000 年成為 RFC 2960,相關(guān)的RFC 3286是介紹性的文檔、RFC 4960(2007)是RFC 2960的替代協(xié)議。

為了適應不斷發(fā)展變化的網(wǎng)絡標準,SCTP也在不斷進化,比如:增加了端到端的認證功能、改進了心跳機制,優(yōu)化了調(diào)度算法。

004d12ec-a55a-11ee-8b88-92fbcf53809c.png

TCP/UDP有其先發(fā)優(yōu)勢,已經(jīng)廣泛應用在網(wǎng)絡的各種場景中。

SCTP作為后來者,目前的應用范圍有限,卻也在越來越多的場景中得到應用,比如:多媒體會議、視頻會議。

Part5今天大家學到了什么?

文檔君為大家總結(jié)了一下,你學會了嗎?

站在TCP的肩膀上,SCTP有一些自己的特點,比如:端點、偶聯(lián)、流、通路。

消息傳輸、多路復用,讓數(shù)據(jù)傳輸更加有效率。

多一次握手,驗證標簽和驗證碼,檢測心跳,SCTP就想給數(shù)據(jù)一些穩(wěn)穩(wěn)的安全感。

一項技術(shù)都是早早出現(xiàn)、慢慢改進、逐步應用,需要經(jīng)過時間的檢驗。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 數(shù)據(jù)傳輸
    +關(guān)注

    關(guān)注

    9

    文章

    2051

    瀏覽量

    66899
  • 協(xié)議
    +關(guān)注

    關(guān)注

    2

    文章

    615

    瀏覽量

    40668
  • SCTP
    +關(guān)注

    關(guān)注

    0

    文章

    7

    瀏覽量

    8371
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    振弦式應變計兩種數(shù)據(jù)傳輸方式介紹

    在巖土工程及結(jié)構(gòu)健康監(jiān)測領(lǐng)域,振弦式應變計憑借其高精度、抗干擾能力強的特性,成為橋梁、隧道、大壩等基礎(chǔ)設施安全監(jiān)測的核心設備。數(shù)據(jù)傳輸方式作為連接傳感器與監(jiān)測系統(tǒng)的“神經(jīng)通路”,直接影響著數(shù)據(jù)
    的頭像 發(fā)表于 07-15 13:38 ?251次閱讀
    振弦式應變計兩種<b class='flag-5'>數(shù)據(jù)傳輸</b>方式介紹

    工業(yè)智能網(wǎng)關(guān)在數(shù)據(jù)傳輸中有哪些功能

    工業(yè)智能網(wǎng)關(guān)在數(shù)據(jù)傳輸中具備協(xié)議轉(zhuǎn)換、數(shù)據(jù)采集與預處理、邊緣計算、安全加密、多通道傳輸、遠程管理與配置、斷點續(xù)傳與
    的頭像 發(fā)表于 07-01 15:16 ?376次閱讀
    工業(yè)智能網(wǎng)關(guān)在<b class='flag-5'>數(shù)據(jù)傳輸</b>中有哪些功能

    像這樣一款體積小巧的DTU數(shù)據(jù)傳輸終端你見過嗎?

    數(shù)據(jù)傳輸
    才茂通信
    發(fā)布于 :2025年06月04日 14:33:29

    檢漏儀通信革命:Modbus轉(zhuǎn)Profinet數(shù)據(jù)傳輸“快人一步”

    選擇VING微硬創(chuàng)新Modbus協(xié)議作為通信標準。 (二)VING微硬創(chuàng)新Profinet協(xié)議 VING微硬創(chuàng)新Profinet網(wǎng)關(guān)是基于工業(yè)以太網(wǎng)的實時工業(yè)通信協(xié)議,具備高速數(shù)據(jù)傳輸
    發(fā)表于 05-19 15:55

    SPI數(shù)據(jù)傳輸緩慢問題求解

    我遇到了 SPI 數(shù)據(jù)傳輸速率問題。 盡管將 SPI 時鐘頻率設置為 20 MHz,但我只獲得了 2 Kbps 的數(shù)據(jù)傳輸速率。 我正在以 115200 的波特率通過 UART 監(jiān)控數(shù)據(jù)。 我正在 cyfxusbspidmamo
    發(fā)表于 05-15 08:29

    iic協(xié)議數(shù)據(jù)傳輸速率標準

    I2C協(xié)議定義了多種數(shù)據(jù)傳輸速率標準,以適應不同的應用需求。以下是I2C協(xié)議的主要數(shù)據(jù)傳輸速率標準: 標準模式(Standard-mode) :速率為100 kbps(每秒100,00
    的頭像 發(fā)表于 02-05 13:40 ?3741次閱讀

    MPU數(shù)據(jù)傳輸協(xié)議詳解

    協(xié)議的基本概念 數(shù)據(jù)傳輸協(xié)議定義了數(shù)據(jù)在MPU和外部設備之間傳輸的方式,包括數(shù)據(jù)的格式、同步方式
    的頭像 發(fā)表于 01-08 09:37 ?1231次閱讀

    總線數(shù)據(jù)傳輸安全性分析

    總線數(shù)據(jù)傳輸安全性分析,特別是針對像CAN(Controller Area Network)總線這樣的重要通信協(xié)議,是一個復雜而關(guān)鍵的課題。以下是對CAN總線數(shù)據(jù)傳輸
    的頭像 發(fā)表于 12-31 09:51 ?1053次閱讀

    如何使用 HTTP 協(xié)議進行數(shù)據(jù)傳輸

    在互聯(lián)網(wǎng)時代,數(shù)據(jù)傳輸是信息交換的基礎(chǔ)。HTTP協(xié)議作為最常用的數(shù)據(jù)傳輸協(xié)議之一,支撐著全球數(shù)十億用戶的數(shù)據(jù)交互。 HTTP
    的頭像 發(fā)表于 12-30 09:24 ?1954次閱讀

    ptp對實時數(shù)據(jù)傳輸的影響

    在現(xiàn)代通信技術(shù)中,點對點(P2P)網(wǎng)絡已經(jīng)成為數(shù)據(jù)傳輸的一種重要方式。P2P網(wǎng)絡允許網(wǎng)絡中的每個節(jié)點既可以作為客戶端也可以作為服務器,直接進行數(shù)據(jù)交換。這種去中心化的網(wǎng)絡結(jié)構(gòu)對于實時數(shù)據(jù)傳輸有著深遠
    的頭像 發(fā)表于 12-29 09:53 ?897次閱讀

    信噪比對數(shù)據(jù)傳輸速度的影響

    到信號檢測和識別的準確性,以及數(shù)據(jù)傳輸可靠性和速度。 二、信噪比對數(shù)據(jù)傳輸速度的影響 影響通信質(zhì)量 : 高的信噪比意味著信號強度遠大于噪聲強度,信號能夠準確地被接收和解碼,從而減少
    的頭像 發(fā)表于 12-10 14:38 ?2428次閱讀

    PCIe數(shù)據(jù)傳輸協(xié)議詳解

    、網(wǎng)卡和聲卡等,以實現(xiàn)高效的數(shù)據(jù)傳輸。以下是對PCIe數(shù)據(jù)傳輸協(xié)議的介紹: 一、PCIe協(xié)議的基本概念 PCIe協(xié)議定義了一系列規(guī)范和要求,
    的頭像 發(fā)表于 11-26 16:12 ?4848次閱讀

    波特率對實時數(shù)據(jù)傳輸的影響

    在現(xiàn)代通信系統(tǒng)中,實時數(shù)據(jù)傳輸是至關(guān)重要的。無論是工業(yè)自動化、遠程醫(yī)療、在線游戲還是物聯(lián)網(wǎng)(IoT)應用,都需要快速、可靠數(shù)據(jù)傳輸來保證系統(tǒng)的正常運行和用戶體驗。 波特率的定義 波特率,也稱為符號
    的頭像 發(fā)表于 11-22 10:03 ?1632次閱讀

    socket 數(shù)據(jù)傳輸效率提升技巧

    在現(xiàn)代網(wǎng)絡應用中,數(shù)據(jù)傳輸效率是衡量系統(tǒng)性能的關(guān)鍵指標之一。對于使用socket進行數(shù)據(jù)傳輸的應用,優(yōu)化傳輸效率不僅可以提升用戶體驗,還能降低成本。 1. 選擇合適的傳輸
    的頭像 發(fā)表于 11-12 14:34 ?1461次閱讀

    CAN總線數(shù)據(jù)傳輸速率設置

    CAN(Controller Area Network)總線是一種串行通信協(xié)議,主要用于汽車和工業(yè)控制系統(tǒng)中,以實現(xiàn)電子控制單元(ECU)之間的通信。CAN總線的數(shù)據(jù)傳輸速率,也稱為波特率,是衡量
    的頭像 發(fā)表于 11-12 10:03 ?3309次閱讀