Netty序列化深入理解與使用
序列化與反序列化
序列化:把對(duì)象轉(zhuǎn)換成字節(jié)的過(guò)程,稱為對(duì)象序列化
反序列化:把字節(jié)恢復(fù)成對(duì)象的過(guò)程,稱為反序列化
- 對(duì)象的持久化概念:把字節(jié)保存的硬盤(pán)上永久的存放
- 網(wǎng)絡(luò)傳輸對(duì)象概念:客戶端將對(duì)象序列化為字節(jié)(序列化),變成二進(jìn)制的形式發(fā)送到服務(wù)器端端,服務(wù)器端接受到字節(jié)對(duì)象后,反序列化成對(duì)象
注意序列化的類(lèi)必須要實(shí)現(xiàn) Serializable 接口, transient 修飾變量使得該變量不被序列化。
網(wǎng)絡(luò)傳輸過(guò)程中不能直接傳輸對(duì)象,TCP協(xié)議的底層是二進(jìn)制。

序列化模式
1.對(duì)象持久化概念:將對(duì)象轉(zhuǎn)換成字節(jié),存放到硬盤(pán)或者是數(shù)據(jù)庫(kù)中
2. 網(wǎng)絡(luò)傳輸對(duì)象概念:客戶端將對(duì)象轉(zhuǎn)成字節(jié)的形式(序列化)、變成二進(jìn)制的形式發(fā)送給服務(wù)器端,服務(wù)器端接受到字節(jié)之后,反序列化成對(duì)象(rpc 遠(yuǎn)程通訊)。
其他對(duì)象序列化方式
1、將對(duì)象轉(zhuǎn)換成json類(lèi)型,實(shí)現(xiàn)跨語(yǔ)言
客戶端將對(duì)象轉(zhuǎn)換程json類(lèi)型,傳遞給服務(wù)器端序列化。
服務(wù)器端獲取到j(luò)son, 在將json轉(zhuǎn)換成對(duì)象反序列化。
2、Xml類(lèi)型
一般比較重量級(jí),一般只有銀行、保險(xiǎn)公司使用這種方式。
3、ProtoBuf(谷歌第三方協(xié)議,谷歌自定義協(xié)議)
4、MessagePack
也屬于json里面的
使用json協(xié)議實(shí)現(xiàn)對(duì)象的傳輸
就是將對(duì)象轉(zhuǎn)換成json字符串進(jìn)行傳輸。
MessagePack編碼器
它像JSON, 但是更快更小。
MessagePack是一種高效的二進(jìn)制序列化格式。它允許您在JSON等多種語(yǔ)之間交換數(shù)據(jù),但它更快速更小巧。小整數(shù)被編碼為單個(gè)字節(jié),典型的短字符串除了字符串本身之外只需要一個(gè)額外的字節(jié)。
支持Python、Ruby、 Java、 C/C++ 等眾多語(yǔ)言。宣稱比Google Protocol Buffers還要快4倍。。
使用案例:
引入mave依賴:
<dependency>
<groupId>org.msgpack</groupId>
<artifactId>msgpack</artifactId>
<version>0.6.12</version>
</dependency>
基本api使用:
// 創(chuàng)建MessagePack MessagePack messagePack = new MessagePack(); MsgEntity meite = new MsgEntity(UUID.randomUUID().toString(), "kaico學(xué)習(xí)"); // 序列化 byte[] bs = messagePack.write(meite); Value read1 = messagePack.read(bs); System.out.println(read1); // 反序列化 MsgEntity read = messagePack.read(bs, MsgEntity.class); System.out.println(read);
在Netty框架中使用
編碼器
public class MsgpackEncoder extends MessageToByteEncoder {
/**
* 對(duì)我們數(shù)據(jù)實(shí)現(xiàn)編碼
*
* @param channelHandlerContext
* @param msg
* @param byteBuf
* @throws Exception
*/
@Override
protected void encode(ChannelHandlerContext channelHandlerContext, Object msg, ByteBuf byteBuf) throws Exception {
MessagePack msgpack = new MessagePack();
byteBuf.writeBytes(msgpack.write(msg));
}
}解碼器
public class MsgpackDecoder extends MessageToMessageDecoder<ByteBuf> {
/**
* 服務(wù)器解碼數(shù)據(jù)
*
* @param channelHandlerContext
* @param byteBuf
* @param list
* @throws Exception
*/
@Override
protected void decode(ChannelHandlerContext channelHandlerContext, ByteBuf byteBuf, List<Object> list) throws Exception {
final int length = byteBuf.readableBytes();
byte[] b = new byte[length];
byteBuf.getBytes(byteBuf.readerIndex(), b, 0, length);
MessagePack msgpack = new MessagePack();
list.add(msgpack.read(b));
}
}服務(wù)端使用
socketChannel.pipeline().addLast(new MsgpackDecoder()); socketChannel.pipeline().addLast(new ServerHandler());
客戶端使用
ch.pipeline().addLast(new MsgpackEncoder()); ch.pipeline().addLast(new ClientHandler());
到此這篇關(guān)于Netty序列化深入理解與使用的文章就介紹到這了,更多相關(guān)Netty序列化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解使用@RequestBody取POST方式的json字符串
這篇文章主要介紹了詳解使用@RequestBody取POST方式的json字符串,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
Java實(shí)現(xiàn)redis分布式鎖的三種方式
本文主要介紹了Java實(shí)現(xiàn)redis分布式鎖的三種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
Java?實(shí)戰(zhàn)項(xiàng)目之學(xué)生信息管理系統(tǒng)的實(shí)現(xiàn)流程
讀萬(wàn)卷書(shū)不如行萬(wàn)里路,只學(xué)書(shū)上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),大家可以在過(guò)程中查缺補(bǔ)漏,提升水平2021-11-11
Java關(guān)系操作符簡(jiǎn)寫(xiě)介紹
下面小編就為大家?guī)?lái)一篇Java關(guān)系操作符簡(jiǎn)寫(xiě)介紹。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05
在Java的Struts中判斷是否調(diào)用AJAX及用攔截器對(duì)其優(yōu)化
這篇文章主要介紹了在Java的Struts中判斷是否調(diào)用AJAX及用攔截器對(duì)其優(yōu)化的方法,Struts框架是Java的SSH三大web開(kāi)發(fā)框架之一,需要的朋友可以參考下2016-01-01
Springboot實(shí)現(xiàn)定時(shí)任務(wù)的4種方式舉例詳解
在我們開(kāi)發(fā)項(xiàng)目過(guò)程中經(jīng)常需要定時(shí)任務(wù)來(lái)幫助我們來(lái)做一些內(nèi)容,下面這篇文章主要給大家介紹了關(guān)于Springboot實(shí)現(xiàn)定時(shí)任務(wù)的4種方式,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
詳解spring mvc(注解)上傳文件的簡(jiǎn)單例子
本篇文章主要介紹了spring mvc(注解)上傳文件的簡(jiǎn)單例子,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01

