Netty杂项
双子星Promise和Future
作用:是实现异步非常重要的一环;也使无锁化串行的实现变得可控,channel中的线程谁先完成无所谓,拿到结果进行回调这一步控制好即可。这样能大大提高CPU利用率
流程、分工::线程不断地与Promise交互,线程执行完之后,Promise通知Future,Future来决定调用哪个回调方法;两者必须成对出现,Promise保存线程执行状态,用来通知Future;Future负责注册跟回调
1.Future
扩展了Future接口,其重要方法为:isSuccess、addListener、sync、await等,为JDK中拥有的,addListener就是用来做回调的;运行在前端层面
2.Promise
也扩展了Future接口,其重要方法如addListener等是类似的,表示一种可写的Future,即可以设置异步执行的结果;运行在后端层面
3.Netty进行的扩展
ChannelPromise:
4.Channel生命周期:
5.ChannelHandler及其子类
Handler类继承图
方法:
5.1 ChannelInboundHandler
数据翻译官:编码和解码
1 TCP黏包和拆包
发生在TCP底层
2 黏包问题的解决方法
第二种方式一般只适合于文本内容
第四种的原理为1、2、3中的一种,规则更复杂了而已
3 编码解码技术
编码器:拆包工具;解码器:黏包工具
4 Netty中的编解码框架
为什么需要?
如何开发?
如果熟悉Netty底层,则直接使用ChannelHandler扩展开发;如果不熟悉,Netty也提供了通用的编解码框架供用户扩展,也提供了常用的编解码类库供用户直接使用,如base64、Protobuf、JBoss、Marshalling、spdy等