Netty心跳机制

来源:互联网 发布:出知西安之咸宁翻译 编辑:程序博客网 时间:2024/05/21 06:43

1.心跳机制目的:判断活着保持链接

2 .如何实现心跳机制:最好在应用层自己实现

一般实现心跳机制由两种方式:

 

   TCP协议自带的心跳机制来实现;

    在应用层来实现。

 

但是TCP协议自带的心跳机制系统默认是设置的是2小时的心跳频率。它检查不到机器断电、网线拔出、防火墙这些断线。而且逻辑层处理断线可能也不是那么好处理。另外该心跳机制是与TCP协议绑定的,那如果我们要是使用UDP协议岂不是用不了?所以一般我们都不用。

 

3.应用层心跳机制的策略

 

大致的策略是这样的:

  1. Client启动一个定时器,不断发送心跳;
  2. Server收到心跳后,做出回应;
  3. Server启动一个定时器,判断Client是否存在,这里做判断有两种方法:时间差和简单标识。

时间差:

  1. 收到一个心跳包之后记录当前时间;
  2. 判断定时器到达时间,计算多久没收到心跳时间=当前时间-上次收到心跳时间。如果改时间大于设定值则认为超时。

简单标识:

  1. 收到心跳后设置连接标识为true;
  2. 判断定时器到达时间,如果未收到心跳则设置连接标识为false;

4 Netty的心跳机制的实现

在Netty中提供了IdleStateHandler类来进行心跳的处理,它可以对一个 Channel 的 读/写设置定时器, 当 Channel 在一定事件间隔内没有数据交互时(即处于 idle 状态), 就会触发指定的事件。

 

IdleStateHandler(intreaderIdleTimeSeconds, int writerIdleTimeSeconds, int allIdleTimeSeconds)

 

    readerIdleTimeSeconds:设置读超时时间;

    writerIdleTimeSeconds:设置写超时时间;

    allIdleTimeSeconds:同时为读或写设置超时时间;

 

原创粉丝点击