概要
用过Netty的小伙伴都知道, 当我们使用了Netty, 就意味着我们使用了Netty…就意味着我们不仅需要处理业务数据, 还需要围绕 连接(Channel) 来添加相当一部分的逻辑, 比如断线重连, 心跳, 重试,读闲置, 写闲置,超时等等进行设置, 此部分的逻辑一般不建议和业务处理器耦合在一起,不仅可读性差, 难维护, 还会引发歧义, 为此Nettyx提供了InboundAdvice和OutboundAdvice来解决此类问题
TIPS: 建议将InboundAdvice放在Pipeline的末尾, OutboundAdvice放在Pipeline开头
那正文开始了, 先引入Nettyx的依赖
请从maven中央仓获取{lastest.version},最新版本号
<dependency>
<groupId>io.github.fbbzl</groupId>
<artifactId>nettyx</artifactId>
<version>{lastest.version}</version>
</dependency>
InboundAdvice
InboundAdvice内部提供了很多 函数字段, 即field类型为函数接口.且名称都以when开头,比如whenChannelInactive,whenChannelActive等等
以下将展示如何通过InboundAdvice简单实现断线重连
private ChannelInitializer<NioSocketChannel> channelInitializer() {
return new ChannelInitializer<NioSocketChannel>() {
@Override
protected void

本文介绍如何使用Netty的ChannelAdvice功能,包括InboundAdvice和OutboundAdvice,以实现断线重连等常见网络通信需求。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



