本篇文章給大家分享的是有關(guān)如何解析Netty,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
成都創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:做網(wǎng)站、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的臨潁網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
關(guān)于Netty ByteBuf:字節(jié)緩沖區(qū) 以內(nèi)存角度可以分為
1、堆內(nèi)存字節(jié)緩沖區(qū),內(nèi)存分配和回收速度快 JVM自動回收,缺點是IO讀寫時需要額外做一次內(nèi)存復(fù)制,將堆內(nèi)存對應(yīng)的緩存區(qū)復(fù)職到內(nèi)核channel中。
2、直接內(nèi)存字節(jié)緩沖區(qū),非堆內(nèi)存,在堆外進(jìn)行內(nèi)存分配,分配和回收會慢一些,但是在讀取時由于少了一次內(nèi)存復(fù)職,速度比堆內(nèi)存快。 在IO通信線程讀寫緩沖區(qū)使用DirectByteBuf,后端業(yè)務(wù)消息編解碼模塊使用HeapByteBuf。
Channel:網(wǎng)絡(luò)IO讀寫相關(guān)的接口
Netty高性能
1、采用異步非阻塞的IO類庫,基于Reactor模式實現(xiàn),多路復(fù)用。
2、TCP接受和發(fā)送緩沖區(qū)使用直接內(nèi)存代替堆內(nèi)存,避免內(nèi)存復(fù)制提升IO讀取和寫入性能
3、支持通過內(nèi)存池的方式循環(huán)利用ByteBuf,避免頻繁創(chuàng)建和銷毀ByteBuf帶來的性能損耗
4、采用環(huán)形數(shù)組緩沖區(qū)實現(xiàn)無鎖化并發(fā)編程
...
主從Reactor多線程模型如下
https://blog.csdn.net/prestigeding/column/info/15042
以上就是如何解析Netty,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。