编码和解码的基本介绍
- 编写网络应用程序时,因为数据在网络中传输的都是二进制字节码数据,在发送数据时就需要编码,接收数据时需要解码。
- codec(编解码器)的组成部分有两个: decoder(解码器)和encoder(编码器)。decoder(解码器)负责把字节码数据转换成业务数据,(编码器)encoder负责把业务数据转换成字节码数据。
Netty本身的编码解码的机制和问题分析
- Netty提供了一些codec(编解码器)
- 编码器
- StringEncoder,对字符串数据进行编码
- ObjectEncoder,对Java对象进行编码
- 解码器
- StringDecoder,对字符串数据进行解码
- ObjectDecoder,对Java对象进行解码
- 编码器
- Netty自带的ObjectDecoder和ObjectEncoder可以用来实现POJO对象或各种业务对象的编码和解码,底层使用的仍是Java序列化技术,而Java序列化技术本身效率就不高,存在如下问题
- 无法跨语言
- 序列化后的体积太大,是二进制编码的5倍多。
- 序列化性能太低
Protobuf
- Protobuf是Google的开源项目,全称Google Protocol Buffers,是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。它很适合做数据存储或RPC[远程过程调用 remote procedure call] 数据交换格式。
- 目前很多公司 http+json tcp+protobuf
- 以message的方式管理数据
- 支持跨平台、跨语言,即[客户端和服务器端可以是不同的语言编写的] (支持目前绝大多数语言,例如 C++、C#、Java、python 等)
- 高性能,高可靠性
- 使用protobuf编译器能自动生成代码,Protobuf是将类的定义使用 .proto文件进行描述。说明,在idea 中编写 .proto 文件时,会自动提示是否下载 ptotot 编写插件,可以让语法高亮。