Netty可靠性设计之Netty心跳机制

2 篇文章 0 订阅

1、使用心跳机制的原因

    在凌晨等业务低谷期,如果发生网络闪断、连接被Hnag住等网络问题时,由于没有业务消息,应用进程很难发现。等到了白天业务高峰期时,会发生大量的网络通信失败,严重的话还会导致一段时间进程内无法处理业务消息。为了解决这个问题,在网络空闲时采用心跳机制来检测链路的互通性,一旦发现网络故障,立即关闭链路,主动重连。

 

2、设计思路

(1)当网络处于空闲状态持续时间达到T(连续周期T没有读写消息)时,客户端只懂发送Ping心跳消息给服务端。

(2)如果在下一个周期T到来时客户端没有收到对方发送的Pong心跳应答消息或者读取到服务端发送的其他业务消息,则心跳失败计数器加1.

(3)每当客户端接收到服务的业务消息或者Pong应答消息时,将心跳失败计数器清零,连续N次没有接收到服务端的Pong消息或者业务消息,则关闭链路,间隔INTERVAL时间后发起重连操作。

(4)服务端网络空闲状态持续时间达到T后,服务端将心跳失败计数器加1;只要接收到客户端发送的Ping消息或者其他业务消息,计数器清零。

(5)服务端连续N次没有接收到客户端的Ping消息或者其他业务消息,则关闭链路,释放资源,等待客户端重连。

 

3、小结

    通过Ping-Pong双向心跳机制,可以保证无论通信哪一方出现网络故障,都能被及时地检测出来,为了防止由于对方短时间内繁忙没有及时返回应答造成的误判,只有连续N次心跳检测都失败才认定链路已经损害,需要关闭链路并重建链路。

    当读或者写心跳消息发生I/O异常的时候,说明线路已经中断,此时需要立即关闭链路,如果时客户端,需要重新发起连接。如果是服务端,需要清空缓存的半包信息,等待客户端重连。

 

内容来源:

《Netty权威指南》.李林锋

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现心跳保活机制是为了确保网络连接的稳定性和可靠性,防止连接因长时间不活动而被关闭。在Spring Boot和Netty中,可以通过以下步骤实现心跳保活机制: 1. 创建一个Netty服务器并设置相关参数,如端口号和TCP参数。可以使用Spring Boot提供的`@Configuration`注解和Netty的`ServerBootstrap`类来完成这一步骤。 2. 使用Netty的`ChannelInitializer`类创建一个处理器来处理客户端的请求,并实现`ChannelInboundHandlerAdapter`类的`channelRead`方法。 3. 在处理器的`channelRead`方法中,判断收到的消息是否为心跳消息。可以根据消息内容或自定义的标识来判断是否为心跳消息。 4. 如果接收到的消息是心跳消息,可以通过向客户端发送一个固定的心跳响应消息来维持连接。可以使用Netty的`ctx.writeAndFlush()`方法来发送心跳响应消息。 5. 如果接收到的消息不是心跳消息,可以继续处理其他业务逻辑。 6. 在处理器的`channelInactive`方法中,可以处理连接断开时的逻辑。可以在此方法中关闭连接、释放资源等操作。 7. 在Netty服务器的配置中,设置心跳超时时间。可以使用Netty的`IdleStateHandler`类来实现心跳超时的检测和处理。 8. 在上述步骤完成后,运行Spring Boot应用程序,并使用客户端发送心跳消息来保持连接。可以通过不断发送心跳消息,来确保连接保持活动状态。 通过以上步骤,就可以在Spring Boot和Netty中实现心跳保活机制,确保网络连接的稳定性和可靠性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值