您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)如何解析Netty,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話(huà)不多說(shuō),跟著小編一起來(lái)看看吧。
關(guān)于Netty ByteBuf:字節(jié)緩沖區(qū) 以?xún)?nèi)存角度可以分為
1、堆內(nèi)存字節(jié)緩沖區(qū),內(nèi)存分配和回收速度快 JVM自動(dòng)回收,缺點(diǎn)是IO讀寫(xiě)時(shí)需要額外做一次內(nèi)存復(fù)制,將堆內(nèi)存對(duì)應(yīng)的緩存區(qū)復(fù)職到內(nèi)核channel中。
2、直接內(nèi)存字節(jié)緩沖區(qū),非堆內(nèi)存,在堆外進(jìn)行內(nèi)存分配,分配和回收會(huì)慢一些,但是在讀取時(shí)由于少了一次內(nèi)存復(fù)職,速度比堆內(nèi)存快。 在IO通信線(xiàn)程讀寫(xiě)緩沖區(qū)使用DirectByteBuf,后端業(yè)務(wù)消息編解碼模塊使用HeapByteBuf。
Channel:網(wǎng)絡(luò)IO讀寫(xiě)相關(guān)的接口
Netty高性能
1、采用異步非阻塞的IO類(lèi)庫(kù),基于Reactor模式實(shí)現(xiàn),多路復(fù)用。
2、TCP接受和發(fā)送緩沖區(qū)使用直接內(nèi)存代替堆內(nèi)存,避免內(nèi)存復(fù)制提升IO讀取和寫(xiě)入性能
3、支持通過(guò)內(nèi)存池的方式循環(huán)利用ByteBuf,避免頻繁創(chuàng)建和銷(xiāo)毀ByteBuf帶來(lái)的性能損耗
4、采用環(huán)形數(shù)組緩沖區(qū)實(shí)現(xiàn)無(wú)鎖化并發(fā)編程
...
主從Reactor多線(xiàn)程模型如下
https://blog.csdn.net/prestigeding/column/info/15042
以上就是如何解析Netty,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。