标签:des style blog http java color
MINA本身提供了一个过滤器类:
org.apache.mina.filter.keepalive
.
KeepAliveFilter
,该过滤器用于在IO空闲的时候发送并且反馈心跳包(keep-alive request/response)。
说到KeepAliveFilter这个类有必要先说一说其构造函数,即实例化该类需要些什么,该类构造函数中参数有三个分别是:
(1)KeepAvlieMessageFactory: 该实例引用用于判断接受与发送的包是否是心跳包,以及心跳请求包的实现
(2)IdleStatus: 该过滤器所关注的空闲状态,默认认为读取空闲。 即当读取通道空闲的时候发送心跳包
(3)KeepAliveRequestTimeoutHandler: 心跳包请求后超时无反馈情况下的处理机制 默认为CLOSE 即关闭连接
首先需要实现接口
KeepAliveMessageFactory
。
该接口中的抽象方法有:
Modifier and Type | Method and Description |
---|---|
Object | getRequest(IoSession session)
Returns a (new) keep-alive request message.
|
Object | getResponse(IoSession session, Object request)
Returns a (new) response message for the specified keep-alive request.
|
boolean | isRequest(IoSession session, Object message)
Returns true if and only if the specified message is a keep-alive request message.
|
boolean | isResponse(IoSession session, Object message)
Returns true if and only if the specified message is a keep-alive response message;
|
一般来说心跳机制主要分为以下四类:
1,
active 活跃型:
当读取通道空闲的时候发送心跳请求,一旦该心跳请求被发送,那么需要在keepAliveRequestTimeout时间内接收到心跳反馈,否则
KeepAliveRequestTimeoutHandler将会被调用,当一个心跳请求包被接受到后,那么心跳反馈也会立即发出。
针对活跃型心跳机制:
KeepAliveMessageFactory
类的实现方法中:
getRequest
(
IoSession
session)与
getResponse
(
IoSession
session,
Object
request)必须返回非空。
2, semi-active 半活跃型:当读取通道空闲的时候发送心跳请求,然而并不在乎心跳反馈有没有,当一个心跳请求包被接收到后,那么心跳反馈也会立即发出。
针对半活跃型心跳机制:
KeepAliveMessageFactory
类的实现方法中:
getRequest
(
IoSession
session)与
getResponse
(
IoSession
session,
Object
request)必须返回非空。并且心跳包请求后超时无反馈的处理机制设置为KeepAliveRequestTimeoutHandler.NOOP(不做任何处理),
KeepAliveRequestTimeoutHandler.LOG(只输出警告信息不做其他处理)
3, passive 被动型:当前IO不希望主动发送心跳请求,但是当接受到一个心跳请求后,那么该心跳反馈也会立即发出。
针对被动型心跳机制:
KeepAliveMessageFactory
类的实现方法中:
getRequest
(
IoSession
session)必须反馈null 与
getResponse
(
IoSession
session,
Object
request)必须反馈non-null.
4, deaf speaker 聋子型: 当前IO会主动发送心跳请求,但是不想发送任何心跳反馈。
针对聋子型心跳机制:
KeepAliveMessageFactory
类的实现方法中:
getRequest
(
IoSession
session)必须反馈non-null与
getResponse
(
IoSession
session,
Object
request)必须反馈null,将
KeepAliveRequestTimeoutHandler
设置为DEAF_SPEAKER.
5, sient-listener 持续监听型:既不想发送心跳请求也不想发送心跳反馈。
针对持续监听型心跳机制:
KeepAliveMessageFactory
类的实现方法中:
getRequest
(
IoSession
session)必须反馈null 与
getResponse
(
IoSession
session,
Object
request)必须反馈null.
心跳包请求超时后的处理机制:接口
KeepAliveRequestTimeoutHandler ,一般该处理主要是针对能够发送心跳请求的心跳机制。
1.CLOSE:关闭连接
2,LOG:输出
警告信息
3,NOOP:不做任何处理
4,EXCEPTION:抛出异常
5,DEAF_SPEAKER:一个特殊的处理,停止当前过滤器对对心跳反馈监听,因此让过滤器丢失请求超时的侦测功能。(让其变成聋子)
6,keepAliveRequestTimeout(KeepAliveFilter filter, IoSession session); 自定义处理
下面对客户端与服务端和分别举个例子:
服务器:
以被动型心跳机制为例,服务器在接受到客户端连接以后被动接受心跳请求,当在规定时间内没有收到客户端心跳请求时 将客户端连接关闭
主要代码如下:
apache MINA之心跳协议运用,布布扣,bubuko.com
标签:des style blog http java color
原文地址:http://www.cnblogs.com/pricks/p/3832882.html