日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

拼多多面試:Netty如何解決粘包問題?

來源: 責(zé)編: 時(shí)間:2024-06-05 17:46:36 158觀看
導(dǎo)讀粘包和拆包問題也叫做粘包和半包問題,它是指在數(shù)據(jù)傳輸時(shí),接收方未能正常讀取到一條完整數(shù)據(jù)的情況(只讀取了部分?jǐn)?shù)據(jù),或多讀取到了另一條數(shù)據(jù)的情況)就叫做粘包或拆包問題。從嚴(yán)格意義上來說,粘包問題和拆包問題屬于兩個(gè)不

IgF28資訊網(wǎng)——每日最新資訊28at.com

粘包和拆包問題也叫做粘包和半包問題,它是指在數(shù)據(jù)傳輸時(shí),接收方未能正常讀取到一條完整數(shù)據(jù)的情況(只讀取了部分?jǐn)?shù)據(jù),或多讀取到了另一條數(shù)據(jù)的情況)就叫做粘包或拆包問題。IgF28資訊網(wǎng)——每日最新資訊28at.com

從嚴(yán)格意義上來說,粘包問題和拆包問題屬于兩個(gè)不同的問題,接下來我們分別來看。IgF28資訊網(wǎng)——每日最新資訊28at.com

1.粘包問題

粘包問題是指在網(wǎng)絡(luò)通信中,發(fā)送方連續(xù)發(fā)送的多個(gè)小數(shù)據(jù)包被接收方一次性接收的現(xiàn)象。這可能是因?yàn)榈讓觽鬏攲訁f(xié)議(如 TCP)會(huì)將多個(gè)小數(shù)據(jù)包合并成一個(gè)大的數(shù)據(jù)塊進(jìn)行傳輸,導(dǎo)致接收方在接收數(shù)據(jù)時(shí)一次性接收了多個(gè)數(shù)據(jù)包,造成粘連。IgF28資訊網(wǎng)——每日最新資訊28at.com

例如以下案例,正常情況下客戶端發(fā)送了兩條消息,分別為“ABC”和“DEF”,那么接收端也應(yīng)該收到兩條消息“ABC”和“DEF”才對(duì),但是接收端卻收到了“ABCD”這樣的消息,這種情況就叫做粘包,如下圖所示:IgF28資訊網(wǎng)——每日最新資訊28at.com

IgF28資訊網(wǎng)——每日最新資訊28at.com

2.拆包/半包問題

拆包問題是指發(fā)送方發(fā)送的一個(gè)大數(shù)據(jù)包被接收方拆分成多個(gè)小數(shù)據(jù)包進(jìn)行接收的現(xiàn)象。這可能是因?yàn)榈讓觽鬏攲訁f(xié)議(如 TCP)將一個(gè)大數(shù)據(jù)包拆分成多個(gè)小的數(shù)據(jù)塊進(jìn)行傳輸,導(dǎo)致接收方在接收數(shù)據(jù)時(shí)分別接收了多個(gè)小數(shù)據(jù)包,造成拆開。IgF28資訊網(wǎng)——每日最新資訊28at.com

例如以下案例,客戶端發(fā)送了一條消息“ABC”,而接收端卻收到了“AB”和“C”兩條信息,這種情況就叫做半包,如下圖所示:IgF28資訊網(wǎng)——每日最新資訊28at.com

IgF28資訊網(wǎng)——每日最新資訊28at.com

IgF28資訊網(wǎng)——每日最新資訊28at.com

PS:大部分情況下我們都把粘包問題和拆包問題看成同一個(gè)問題,所以下文就用粘包問題來替代粘包和拆包問題。IgF28資訊網(wǎng)——每日最新資訊28at.com

3.為什么會(huì)有粘包問題?

粘包問題通常發(fā)生在 TCP/IP 協(xié)議中,因?yàn)?TCP 是面向連接的傳輸協(xié)議,它是以“流”的形式傳輸數(shù)據(jù)的,而“流”數(shù)據(jù)是沒有明確的開始和結(jié)尾邊界的,所以就會(huì)出現(xiàn)粘包問題。IgF28資訊網(wǎng)——每日最新資訊28at.com

4.常見解決方案

粘包問題的常見解決方案有以下 3 種:IgF28資訊網(wǎng)——每日最新資訊28at.com

  • 固定大小方法:發(fā)送方和接收方固定發(fā)送數(shù)據(jù)大小,當(dāng)字符長度不夠時(shí)用空字符彌補(bǔ),有了固定大小之后就知道每條消息的具體邊界了,這樣就沒有粘包的問題了。
  • 自定義數(shù)據(jù)協(xié)議(定義數(shù)據(jù)長度):在 TCP 協(xié)議的基礎(chǔ)上封裝一層自定義數(shù)據(jù)協(xié)議,在自定義數(shù)據(jù)協(xié)議中,包含數(shù)據(jù)頭(存儲(chǔ)數(shù)據(jù)的大小)和 數(shù)據(jù)的具體內(nèi)容,這樣服務(wù)端得到數(shù)據(jù)之后,通過解析數(shù)據(jù)頭就可以知道數(shù)據(jù)的具體長度了,也就沒有粘包的問題了。
  • 特殊分割符:以特殊的字符結(jié)尾,比如以“/n”結(jié)尾,這樣我們就知道數(shù)據(jù)的具體邊界了,從而避免了粘包問題。

以上三種方案中,第一種固定大小的方法可能會(huì)造成網(wǎng)絡(luò)流量的浪費(fèi),以及傳輸性能慢的問題;第二種解決方案實(shí)現(xiàn)難度大,且不利于維護(hù),所以比較推薦的是第三種方案,使用特殊分隔符來區(qū)分消息的邊界,從而避免粘包問題。IgF28資訊網(wǎng)——每日最新資訊28at.com

5.Netty解決方案

Netty 解決方案也延續(xù)了上面的常見解決方案,它的解決方案有以下幾個(gè):IgF28資訊網(wǎng)——每日最新資訊28at.com

  • 使用定長解碼器(FixedLengthFrameDecoder):每個(gè)數(shù)據(jù)包都擁有固定的長度,接收端根據(jù)固定長度對(duì)數(shù)據(jù)進(jìn)行切分,從而解決了粘包問題。
  • 使用行分隔符解碼器(LineBasedFrameDecoder):以行為單位進(jìn)行數(shù)據(jù)包的解碼,從而解決粘包問題。
  • 使用分隔符解碼器(DelimiterBasedFrameDecoder):使用特定的分隔符來標(biāo)識(shí)消息邊界,這樣接收端可以根據(jù)分隔符正確切分消息。
  • 使用長度字段解碼器(LengthFieldBasedFrameDecoder):在消息頭部加入表示消息長度的字段,接收端根據(jù)長度字段來確定消息的邊界,而從解決粘包問題。

IgF28資訊網(wǎng)——每日最新資訊28at.com

PS:在 Netty 中,解碼器(Decoder)起著非常重要的作用。解碼器主要負(fù)責(zé)將從網(wǎng)絡(luò)中接收到的原始字節(jié)流數(shù)據(jù)轉(zhuǎn)換為應(yīng)用程序能夠理解的 Java 對(duì)象或消息格式。使用解碼器可以解決粘包和拆包問題、協(xié)議轉(zhuǎn)換問題、消息編碼(如文本轉(zhuǎn)換為字節(jié)流)等問題。IgF28資訊網(wǎng)——每日最新資訊28at.com

這些解碼器的使用如下。IgF28資訊網(wǎng)——每日最新資訊28at.com

(1)定長解碼器

定長解碼器(FixedLengthFrameDecoder)使用示例如下:IgF28資訊網(wǎng)——每日最新資訊28at.com

ChannelPipeline pipeline = ch.pipeline();// 假設(shè)每條消息長度為 5pipeline.addLast(new FixedLengthFrameDecoder(5)); pipeline.addLast(new StringDecoder());pipeline.addLast(new YourBusinessLogicHandler());

(2)行分隔符解碼器

行分隔符解碼器(LineBasedFrameDecoder)使用示例如下:IgF28資訊網(wǎng)——每日最新資訊28at.com

ChannelPipeline pipeline = ch.pipeline();// 設(shè)置行分隔符解碼器最大(幀)長度為 8192 字節(jié)pipeline.addLast(new LineBasedFrameDecoder(8192)); pipeline.addLast(new StringDecoder()); // 添加字符串解碼器pipeline.addLast(new SimpleChannelInboundHandler<String>() {    @Override    protected void channelRead0(ChannelHandlerContext ctx, String msg) throws Exception {        System.out.println("接收到消息:" + msg);    }});

(3)分隔符解碼器

分隔符解碼器(DelimiterBasedFrameDecoder)使用示例如下:IgF28資訊網(wǎng)——每日最新資訊28at.com

ChannelPipeline pipeline = ch.pipeline();// 使用 /r/n 來進(jìn)行分隔ByteBuf delimiter = Unpooled.copiedBuffer("/r/n".getBytes());pipeline.addLast(new DelimiterBasedFrameDecoder(1024, delimiter));pipeline.addLast(new StringDecoder());pipeline.addLast(new YourBusinessLogicHandler());

(4)長度字段解碼器

長度字段解碼器(LengthFieldBasedFrameDecoder)使用示例如下:IgF28資訊網(wǎng)——每日最新資訊28at.com

ChannelPipeline pipeline = ch.pipeline();// 設(shè)置最大幀長度為 1024 字節(jié),長度字段位于第 0 個(gè)字節(jié),長度字段占用 4 個(gè)字節(jié)pipeline.addLast(new LengthFieldBasedFrameDecoder(1024, 0, 4, 0, 4));pipeline.addLast(new LengthFieldPrepender(4));pipeline.addLast(new StringDecoder());pipeline.addLast(new StringEncoder());pipeline.addLast(new LengthFieldServerHandler());

本文鏈接:http://www.www897cc.com/showinfo-26-92177-0.html拼多多面試:Netty如何解決粘包問題?

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: 項(xiàng)目亮點(diǎn):分析與解決小程序頁面切換過程卡頓的問題

下一篇: 我們?nèi)绾瓮V故褂?Git Rebase

標(biāo)簽:
  • 熱門焦點(diǎn)
  • K60 Pro官方停產(chǎn) 第三方瞬間漲價(jià)

    雖然沒有官方宣布,但Redmi的一些高管也已經(jīng)透露了,Redmi K60 Pro已經(jīng)停產(chǎn)且不會(huì)補(bǔ)貨,這一切都是為了即將到來的K60 Ultra鋪路,屬于廠家的正常操作。但有意思的是該機(jī)在停產(chǎn)之后
  • 6月iOS設(shè)備好評(píng)榜:第一蟬聯(lián)榜首近一年

    作為安兔兔各種榜單里變化最小的那個(gè),2023年6月的iOS好評(píng)榜和上個(gè)月相比沒有任何排名上的變化,僅僅是部分設(shè)備好評(píng)率的下降,長年累月的用戶評(píng)價(jià)和逐漸退出市場(chǎng)的老款機(jī)器讓這
  • 容量越大越不壞?24萬塊硬盤故障率報(bào)告公布 這些產(chǎn)品零故障

    8月5日消息,云存儲(chǔ)服務(wù)商Backblaze發(fā)布了最新的硬盤故障率報(bào)告,年故障率有所上升。Backblaze發(fā)布的硬盤季度統(tǒng)計(jì)數(shù)據(jù),其中包括故障率等重要方面。這些結(jié)
  • iPhone賣不動(dòng)了!蘋果股價(jià)創(chuàng)年內(nèi)最大日跌幅:市值一夜蒸發(fā)萬億元

    8月5日消息,今天凌晨美股三大指數(shù)高開低走集體收跌,道指跌0.41%;納指跌0.36%;標(biāo)普500指數(shù)跌0.52%。熱門科技股也都變化極大,其中蘋果報(bào)181.99美元,跌4.8%,創(chuàng)
  • 線程通訊的三種方法!通俗易懂

    線程通信是指多個(gè)線程之間通過某種機(jī)制進(jìn)行協(xié)調(diào)和交互,例如,線程等待和通知機(jī)制就是線程通訊的主要手段之一。 在 Java 中,線程等待和通知的實(shí)現(xiàn)手段有以下幾種方式:Object 類下
  • SpringBoot中使用Cache提升接口性能詳解

    環(huán)境:springboot2.3.12.RELEASE + JSR107 + Ehcache + JPASpring 框架從 3.1 開始,對(duì) Spring 應(yīng)用程序提供了透明式添加緩存的支持。和事務(wù)支持一樣,抽象緩存允許一致地使用各
  • 讓我們一起聊聊文件的操作

    文件【1】文件是什么?文件是保存數(shù)據(jù)的地方,是數(shù)據(jù)源的一種,比如大家經(jīng)常使用的word文檔、txt文件、excel文件、jpg文件...都是文件。文件最主要的作用就是保存數(shù)據(jù),它既可以保
  • 阿里大調(diào)整

    來源:產(chǎn)品劉有媒體報(bào)道稱,近期淘寶天貓集團(tuán)啟動(dòng)了近年來最大的人力制度改革,涉及員工績效、層級(jí)體系等多個(gè)核心事項(xiàng),目前已形成一個(gè)初步的&ldquo;征求意見版&rdquo;:1、取消P序列
  • 8月見!小米MIX Fold 3獲得3C認(rèn)證:支持67W快充

    這段時(shí)間以來,包括三星、一加、榮耀等等有不少品牌旗下的最新折疊屏旗艦都得到了不少爆料,而小米新一代折疊屏旗艦——小米MIX Fold 3此前也屢屢被傳
Top 主站蜘蛛池模板: 乐都县| 新乡县| 姚安县| 大厂| 姜堰市| 右玉县| 台东县| 来宾市| 颍上县| 福海县| 凭祥市| 临猗县| 莲花县| 阿合奇县| 溧水县| 桂平市| 昂仁县| 临猗县| 绥滨县| 全州县| 永善县| 台南市| 武川县| 临猗县| 葵青区| 随州市| 增城市| 腾冲县| 旺苍县| 新余市| 和顺县| 措美县| 永春县| 沈阳市| 江达县| 新余市| 丰都县| 富锦市| 北碚区| 涞水县| 诏安县|