[導(dǎo)讀] UDP 與TCP的區(qū)別
背景
本題是我在面試中,技術(shù)總監(jiān)問我的一道真題,當(dāng)時答得不太好,所以把它揪出來總結(jié)了下。后來問了下總監(jiān),總監(jiān)說這是阿里的面試題。。
其實面試官主要是想讓我說出 UDP 和 TCP 的原理上的區(qū)別,怎么給 UDP 加些功能實現(xiàn) TCP。
看好去很容易就能說出一兩個 TCP 和 UDP 的區(qū)別,但如果能用女朋友都能聽懂的方式該怎么說呢?
女朋友:我不想聽課本上講的!我聽不懂呀~
下面我會以大白話的方式來解答上面的問題。
UDP 的特點
UDP 讓我想起了剛畢業(yè)參加工作那會,一名畢業(yè)菜鳥。
領(lǐng)導(dǎo)安排的任務(wù),直接干就完了。
UDP 也是,相信網(wǎng)絡(luò)世界永遠(yuǎn)是美好的,我發(fā)送的包是很容易送到的,接收方也是很容易組裝的。數(shù)據(jù)結(jié)構(gòu)也很簡單,不需要大量的數(shù)據(jù)結(jié)構(gòu)、處理邏輯、包頭字段。
測試人員報的 bug 我也不會和她爭論什么,永遠(yuǎn)相信測試人員是對的,測試人員說啥就是啥,我改就是。
UDP 也是,不會建立連接,有個端口號,誰都可以監(jiān)聽這個端口號往上面發(fā)數(shù)據(jù)。也可以從這個端口號傳給任何人數(shù)據(jù)。反正我只管發(fā)就是。
產(chǎn)品經(jīng)理昨天說手機殼需要根據(jù)心情變色,測試人員說這個 bug 要把關(guān)聯(lián)的兩個 bug 一起修掉。那就按照他們說的做吧!
UDP 也是,不懂堅持和退讓。也就是根據(jù)網(wǎng)絡(luò)情況進行擁塞控制。無論網(wǎng)絡(luò)丟包多嚴(yán)重,我還是照樣發(fā)~
UDP 使用場景
針對像我那時候畢業(yè)菜鳥的情況,領(lǐng)導(dǎo)給我安排了三種工作環(huán)境讓我選。
-
內(nèi)部系統(tǒng),任務(wù)簡單,模塊單一,不需要考慮代碼的關(guān)聯(lián)影響,即使失敗了也沒有關(guān)系。
UDP 也是,需要資源少,網(wǎng)絡(luò)情況比較好的內(nèi)網(wǎng),或者對于丟包不敏感的應(yīng)用。
-
有一個強力的團隊支持,都是中高級開發(fā)、測試人員,團隊成員打過很多年交道,互相信任。有什么問題,吼一嗓子就可以了!
UDP 也是,不需要一對一溝通來建立連接,可以廣播的應(yīng)用。
-
一個新項目,需要有激情,對于剛畢業(yè)的菜鳥,都是有很強的自主能動性的,也不會?;^,躲在廁所玩手機,帶薪拉shi ?即使項目不忙,我也抓緊時間干。項目忙,還是一樣干!
UDP 也是,猛著發(fā)包就是,主要應(yīng)用在需要處理速度快,時延低,可以容忍少數(shù)丟包的情況。即使網(wǎng)絡(luò)情況不佳,發(fā)包就是~
針對上面的三大場景,UDP 常用在實時競技游戲,IoT 物聯(lián)網(wǎng),移動通信領(lǐng)域。
TCP 的特點?
TCP 和 UDP 是傳輸層里面比較重要的兩個協(xié)議。大部分面試的時候都會問到兩者的區(qū)別。而大部分都會兩句,比如 TCP 是面向連接的,UDP 是面向無連接。
那什么是面向連接?
TCP 三次握手是我們常常念叨和背誦的。而在這三次握手成功后,就是建立連接成功。
那什么又叫面向呢?
我們也常聽到面向?qū)ο缶幊獭⒚嫦蚯忻婢幊?、面向服?wù)編程。那到底什么是面向?
在我看來 面向 就是遵循一定的協(xié)議、規(guī)范、數(shù)據(jù)結(jié)構(gòu)等來做一系列事情。
比如面向連接,就是為了在客戶端和服務(wù)端維護連接,而建立一定的數(shù)據(jù)結(jié)構(gòu)來維護雙方交互的狀態(tài),用這樣的數(shù)據(jù)來保證所謂的面向連接的特性。
知道了 TCP 的是用三次握手來建立連接,那我們是否可以讓 UDP 也發(fā)三個包來模擬 TCP 建立連接?可以是可以,但是如果只是建立,而不是面向連接,其實意義不大。
那 TCP 面向連接做了哪些事情?
TCP 提供可靠交付,通過 TCP 連接傳輸?shù)臄?shù)據(jù),可以無差錯、不丟失、不重復(fù)、并且按序到達(dá)。而 UDP 繼承了 IP 包的特性,不保證不丟失,不保證按順序到達(dá)。
TCP 是面向字節(jié)流,所謂字節(jié)流,就是發(fā)的是一個流,沒頭沒尾。TCP 自己維護流狀態(tài)。
UDP 基于 IP 數(shù)據(jù)報,一個一個地發(fā),一個一個地收。
TCP 擁有擁塞控制,如果包丟棄了或者網(wǎng)絡(luò)環(huán)境不好了,就會根據(jù)網(wǎng)絡(luò)情況自行控制自己的行為,看下是發(fā)快點還是發(fā)慢點。
UDP 則沒有這么智能了, 你讓我發(fā),我就發(fā)唄,反正是你讓我發(fā)的,其他的一概不管~
TCP 是一個有狀態(tài)的服務(wù),有狀態(tài)可以理解為:我記錄了哪些發(fā)送了,哪些沒有發(fā)送,哪些接收到了,哪些沒接收到,應(yīng)該接收哪個了,一點差錯都不行。TCP 干的事情可真多!
而 UDP 則不是有狀態(tài)的服務(wù),我只管發(fā),其他的就交給接收端吧,有點任性是吧?
如何讓 UDP 實現(xiàn) TCP 功能?
建立連接上面已經(jīng)講到了,三次握手和四次握手,UDP 也可以模擬去做。
那下面還有幾個問題:
TCP 的數(shù)據(jù)結(jié)構(gòu)長這樣:
其實如果你能把這些結(jié)構(gòu)講清楚,就已經(jīng)理解了 TCP 的核心功能。下面我還是用大白話的方式來講解上面的四個問題。
順序問題和丟包問題可以利用確認(rèn)與重發(fā)的機制。假如包收到了,可以做一個確認(rèn),發(fā)送一個 ACK 給發(fā)送端,告訴他我收到了。假如有的包提前到了,就緩存著。假如有包丟失了,就可以超時重試。超時重試不宜過短,時間必須大于往返時間 RTT,否則會引起不必要的重傳。也不宜過長,如果超時時間過長,訪問就變慢了。那怎么確定這個時間,可以通過采樣 RTT 的時間,進行加權(quán)平均。還需要根據(jù)網(wǎng)絡(luò)狀況,動態(tài)變化??梢粤私庀伦赃m應(yīng)重傳算法。
流量控制就是根據(jù)網(wǎng)絡(luò)情況調(diào)整發(fā)包的速率。利用的是滑動窗口。在對于包的確認(rèn)中,同時會攜帶一個窗口的大小,只要利用好這個窗口大小,就能很好地調(diào)整發(fā)包速率,發(fā)的報文段不要超過窗口的大小就 OK。(圖片來源網(wǎng)絡(luò))
擁塞控制主要用來避免包丟失和超時重傳,如果出現(xiàn)了這兩種現(xiàn)象,就說明發(fā)的速率太快了。那最開始怎么知道發(fā)送速率呢?其實開始時只發(fā)送一個報文段數(shù)據(jù),如果收到一個確認(rèn),則倍增報文段,依次類推。當(dāng)發(fā)現(xiàn)超時重傳時,就又回到只發(fā)送一個報文段的情況,這個就是慢啟動,這種方式不合適。其實還有一種快速重傳算法,簡單來說就是擁塞窗口減半,后續(xù)線性增速。針對于算法怎么實現(xiàn)的,這里就不展開講述了。(圖片來源網(wǎng)絡(luò))
至此,我用大白話的方式講解了 UDP 和 TCP 的區(qū)別,以及 UDP 缺什么功能,需要怎么去彌補才能實現(xiàn) TCP 的功能。相信這樣回答的思路可以讓面試官覺得還是有點東西的。
巨人的肩膀:
《趣談網(wǎng)絡(luò)協(xié)議》
《計算機網(wǎng)絡(luò)》
- END -
本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。
關(guān)鍵字:
驅(qū)動電源
在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。
關(guān)鍵字:
工業(yè)電機
驅(qū)動電源
LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...
關(guān)鍵字:
驅(qū)動電源
照明系統(tǒng)
散熱
根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。
關(guān)鍵字:
LED
設(shè)計
驅(qū)動電源
電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...
關(guān)鍵字:
電動汽車
新能源
驅(qū)動電源
在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...
關(guān)鍵字:
發(fā)光二極管
驅(qū)動電源
LED
在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...
關(guān)鍵字:
LED照明技術(shù)
電磁干擾
驅(qū)動電源
開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源
關(guān)鍵字:
LED
驅(qū)動電源
開關(guān)電源
LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。
關(guān)鍵字:
LED
隧道燈
驅(qū)動電源
LED驅(qū)動電源在LED照明系統(tǒng)中扮演著至關(guān)重要的角色。由于LED具有節(jié)能、環(huán)保、長壽命等優(yōu)點,使得LED照明在各個領(lǐng)域得到廣泛應(yīng)用。然而,LED的電流、電壓特性需要特定的驅(qū)動電源才能正常工作。本文將介紹常用的LED驅(qū)動電...
關(guān)鍵字:
LED驅(qū)動電源
led照明
LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電源轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。
關(guān)鍵字:
LED
驅(qū)動電源
高壓工頻交流
崧盛股份9日發(fā)布投資者關(guān)系活動記錄表,就植物照明發(fā)展趨勢、行業(yè)壁壘等問題進行分享。植物照明未來市場需求廣闊崧盛股份指出,植物照明將會走向長期產(chǎn)業(yè)領(lǐng)域。主要原因有三:第一,LED植物照明賦能終端種植更具有經(jīng)濟價值。由于LE...
關(guān)鍵字:
崧盛股份
驅(qū)動電源
在當(dāng)今高度發(fā)展的技術(shù)中,電子產(chǎn)品的升級越來越快,LED燈技術(shù)也在不斷發(fā)展,這使我們的城市變得豐富多彩。 LED驅(qū)動電源將電源轉(zhuǎn)換為特定的電壓和電流,以驅(qū)動LED發(fā)光。通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流電(即...
關(guān)鍵字:
LED
驅(qū)動電源
高壓直流
人類社會的進步離不開社會上各行各業(yè)的努力,各種各樣的電子產(chǎn)品的更新?lián)Q代離不開我們的設(shè)計者的努力,其實很多人并不會去了解電子產(chǎn)品的組成,比如LED電源。
關(guān)鍵字:
LED
驅(qū)動電源
低壓直流
隨著科學(xué)技術(shù)的發(fā)展,LED技術(shù)也在不斷發(fā)展,為我們的生活帶來各種便利,為我們提供各種各樣生活信息,造福著我們?nèi)祟?。LED驅(qū)動電源實際上是一種電源,但是它是一種特定的電源,用于驅(qū)動LED發(fā)射帶有電壓或電流的光。 因此,LE...
關(guān)鍵字:
LED
驅(qū)動電源
電流
LED燈作為一種新型節(jié)能和無污染光源,由于其特有的發(fā)光照明特性,在現(xiàn)代照明應(yīng)用中發(fā)揮著革命性的作用。作為 LED 照明產(chǎn)業(yè)鏈中最為核心的部件之一,LED 驅(qū)動電源的驅(qū)動控制技術(shù)所存在的可靠性低、成本高等典型問題一直制約著...
關(guān)鍵字:
多路
LED
驅(qū)動電源
隨著社會的快速發(fā)展,LED技術(shù)也在飛速發(fā)展,為我們的城市的燈光煥發(fā)光彩,讓我們的生活越來越有趣,那么你知道LED需要LED驅(qū)動電源嗎?那么你知道什么是LED驅(qū)動電源嗎?
關(guān)鍵字:
LED
開關(guān)電源
驅(qū)動電源
早前有新聞稱,Cree在2018年開始宣布轉(zhuǎn)型高科技半導(dǎo)體領(lǐng)域,并一邊逐漸脫離照明與LED相關(guān)業(yè)務(wù),一邊持續(xù)投資半導(dǎo)體。在今日,Cree宣布與SMART Global Holdings, Inc.達(dá)成最終協(xié)議,擬將LED...
關(guān)鍵字:
cree
led照明