MINA(Multipurpose Infrastructure for Network Applications)
--
MINA 是一个网络应用框架,帮助用户简化高性能和高伸缩性的网络应用程序的开发.
提供 抽象的 事件驱动 异步API 在多样的传输(TCP/IP, UDP/IP)通过 JAVA NIO.
通常认为 MINA 是一个 NIO框架库, C/S框架, 网络Socket库.
下载:
[url]http://mina.apache.org/mina-project/downloads.html[/url]
安装:
+- dist MINA 包
+- docs 文档
+- lib 依赖 包
+- src
TCP DEMO:
mina-core-2.0.7.jar
mina-example-2.0.7.jar
slf4j-api-1.6.6.jar
slf4j-log4j12-1.6.6.jar
log4j-1.2.17.jar
java org.apache.mina.example.gettingstarted.timeserver.MinaTimeServer
CMD> telnet 127.0.0.1 9123
MINA的三层架构:
I/O Service - 执行实际的 I/O
I/O Filter Chain - 数据转换
I/O Handler - 业务逻辑
服务端架构:
IO Acceptor 监听端口连接与数据包,创建会话
IO Filter Chain 编码/解码, 字节转换成对象
IO Handler 处理对象逻辑
客户端架构
IO Connector
IO Handler
IO Filter Chain
DEMO 详解:
TCP服务器
--
根据服务端架构, 创建一个TCP服务器必须先创建 IO Acceptor 并指定监听端口.
IoAcceptor acceptor = new NioSocketAcceptor();
acceptor.bind( new InetSocketAddress(9123) );
在监听开始前我们要指定协议来转换二进制字节数据为对应协议的消息. 并指定解码器.
IoAcceptor acceptor = new NioSocketAcceptor();
acceptor.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new TextLineCodecFactory( Charset.forName( "UTF-8" ))));
acceptor.bind( new InetSocketAddress(91233) );
在监听开始前我们还要指定消息如何处理, 实现IOHandler接口或继承IoHandlerAdapter的类即是IO处理器:
IO处理器监听会话,并处理消息接收与发送,异常处理.分别对应7个方法:
IoAcceptor acceptor = new NioSocketAcceptor();
acceptor.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new TextLineCodecFactory( Charset.forName( "UTF-8" ))));
acceptor.setHandler( new TimeServerHandler() );
acceptor.bind( new InetSocketAddress(91233) );
接下来,需要配置会话参数:
读缓冲区大小, 空闲时间.
acceptor.getSessionConfig().setReadBufferSize( 2048 );
acceptor.getSessionConfig().setIdleTime( IdleStatus.BOTH_IDLE, 10 );
public class MinaTimeServer
{
private static final int PORT = 9123;
public static void main( String[] args ) throws IOException
{
IoAcceptor acceptor = new NioSocketAcceptor();
acceptor.getFilterChain().addLast( "logger", new LoggingFilter() );
acceptor.getFilterChain().addLast( "codec", new ProtocolCodecFilter( new TextLineCodecFactory( Charset.forName( "UTF-8" ))));
acceptor.setHandler( new TimeServerHandler() );
acceptor.getSessionConfig().setReadBufferSize( 2048 );
acceptor.getSessionConfig().setIdleTime( IdleStatus.BOTH_IDLE, 10 );
acceptor.bind( new InetSocketAddress(PORT) );
}
}