Netty杂项

双子星Promise和Future

作用:是实现异步非常重要的一环;也使无锁化串行的实现变得可控,channel中的线程谁先完成无所谓,拿到结果进行回调这一步控制好即可。这样能大大提高CPU利用率

流程、分工::线程不断地与Promise交互,线程执行完之后,Promise通知Future,Future来决定调用哪个回调方法;两者必须成对出现,Promise保存线程执行状态,用来通知Future;Future负责注册跟回调
Netty杂项

1.Future

Netty杂项
扩展了Future接口,其重要方法为:isSuccess、addListener、sync、await等,为JDK中拥有的,addListener就是用来做回调的;运行在前端层面

2.Promise

也扩展了Future接口,其重要方法如addListener等是类似的,表示一种可写的Future,即可以设置异步执行的结果;运行在后端层面

3.Netty进行的扩展

ChannelPromise:
Netty杂项

4.Channel生命周期:

Netty杂项

5.ChannelHandler及其子类

Handler类继承图
Netty杂项
方法:
Netty杂项

5.1 ChannelInboundHandler

Netty杂项

数据翻译官:编码和解码

1 TCP黏包和拆包

发生在TCP底层
Netty杂项

2 黏包问题的解决方法

Netty杂项
第二种方式一般只适合于文本内容

第四种的原理为1、2、3中的一种,规则更复杂了而已

3 编码解码技术

Netty杂项
编码器:拆包工具;解码器:黏包工具

4 Netty中的编解码框架

为什么需要?
Netty杂项
如何开发?

如果熟悉Netty底层,则直接使用ChannelHandler扩展开发;如果不熟悉,Netty也提供了通用的编解码框架供用户扩展,也提供了常用的编解码类库供用户直接使用,如base64、Protobuf、JBoss、Marshalling、spdy等
Netty杂项