MINA学习汇总

MINA学习汇总

Apache Mina Server
是一个网络通信应用框架,用于开发高性能和高可用性的网络应用程序。它主要是对基于TCP/IP、UDP/IP协议栈的通信框架(然,也可以提供JAVA
对象的序列化服务、虚拟机管道通信服务等),Mina 提供了事件驱动、异步(Mina 的异步IO 默认使用的是JAVA NIO
作为底层支持)操作的编程模型。

Apache Mina简单理解它是一个封装底层IO操作,提供高级操作API的通讯框架!

Mina在整个网通通信结构中位置:

Mina处于中间层,它不关心底层网络数据如何传输,只负责接收底层数据,过滤并转换为Java对象提供给我们的应用程序,然后把应用程序响应值过滤并转换为底层识别的字节,提供给底层传输;

------总之:Mina是底层数据传输和用户应用程序交互的接口!

Mina工作流程图如下:

这个流程图不仅很直观的看出了Mina的工作流程,也涵盖了Mina的三个核心接口:IoService接口,IoFilter接口和IoHandler接口:

l  第一步. 创建服务对象(客户端或服务端)  ---IoService接口实现

l  第二步.
数据过滤(编码解码等)         
---IOFilter接口实现

l  第三步.
业务处理                       
---IoHandler接口实现

IoAccepter 相当于网络应用程序中的服务器端

IoConnector 相当于客户端

IoSession 当前客户端到服务器端的一个连接实例

IoHandler 业务处理逻辑

IoFilter 过滤器用于悬接通讯层接口与业务层接口

Mina的精髓是IOFilter,它可以进行日志记录,信息过滤,编码解码等操作,把数据接收发送从业务层独立出来。

创建服务对象,则是把NIO繁琐的部分进行封装,提供简洁的接口。

业务处理是我们最关心的部分,跟普通的应用程序没任何分别。

1.IoService接口

作用:IoService是创建服务的顶层接口,无论客户端还是服务端,都是从它继承实现的。

类结构

常用接口为:IoService,IoAcceptor,IoConnector

常用类为:NioSocketAcceptor,NioSocketConnector

类图如下:

IoService是创建服务端和客户端的接口,实际应用中我们大多都是应用它的实现类来创建服务对象

2.IoFilter接口

Mina最主要的工作就是把底层传输的字节码转换为Java对象,提供给应用程序;或者把应用程序返回的结果转换为字节码,交给底层传输。这些都是由IoFilter完成的,因此IoFilter是Mina的精髓所在。

在Mina程序中,IoFilter是必不可少的;有了它,Mina的层次结构才异常清晰:

IoFilter   ----   消息过滤

IoHandler  ----   业务处理

Filter,过滤器的意思。IoFilter,I/O操作的过滤器。IoFilter和Servlet中的过滤器一样,主要用于拦截和过滤网络传输中I/O操作的各种消息

类结构

常用接口为:IoFilter,IoFilterChainBuilder

常用类为:IoFilterAdapter,DefaultIoFilterChainBuilder

ProtocolCodecFilter,LoggingFilter

类图如下:

可以在IoService中添加多个IoFilter

eg:

// 创建一个非阻塞的server端的Socket

acceptor = new NioSocketAcceptor();

// 设置日志过滤器

acceptor.getFilterChain().addLast("logger",new
LoggingFilter());

// 设置过滤器(使用Mina提供的文本换行符编解码器)

acceptor.getFilterChain().addLast(

"codec",

new ProtocolCodecFilter(new
TextLineCodecFactory(Charset

.forName("UTF-8"),

LineDelimiter.WINDOWS.getValue(),

LineDelimiter.WINDOWS.getValue())));

// 获得IoSessionConfig对象

IoSessionConfig cfg = acceptor.getSessionConfig();

// 读写通道10秒内无操作进入空闲状态

cfg.setIdleTime(IdleStatus.BOTH_IDLE, 10);

// 绑定逻辑处理器

acceptor.setHandler(new Demo1ServerHandler());

// 绑定端口

acceptor.bind(new InetSocketAddress(PORT));

logger.info("服务端启动成功...     端口号为:" +
PORT);

IoFilter是转码和解码用滴。在实际的应用开发中,自定义协议是必用的,因为很多客户端和服务端是不同语言实现的。

3.IoHandler接口

IoHandler是Mina实现其业务逻辑的顶级接口;它相当简单,你就理解它是根据事件触发的简单应用程序即可。

在IoHandler中定义了7个方法,根据I/O事件来触发对应的方法:

import java.io.IOException;

public interface IoHandler
{

void
sessionCreated(IoSession session) throws Exception;

void sessionOpened(IoSession
session) throws Exception;

void sessionClosed(IoSession
session) throws Exception;

void sessionIdle(IoSession
session, IdleStatus status) throws Exception;

void
exceptionCaught(IoSession session, Throwable cause) throws
Exception;

void
messageReceived(IoSession session, Object message) throws
Exception;

void messageSent(IoSession
session, Object message) throws Exception;

}

sessionCreated:当一个新的连接建立时,由I/O processor thread调用;

sessionOpened:当连接打开是调用;

messageReceived:当接收了一个消息时调用;

messageSent:当一个消息被(IoSession#write)发送出去后调用;

sessionIdle:当连接进入空闲状态时调用;

sessionClosed:当连接关闭时调用;

exceptionCaught:当实现IoHandler的类抛出异常时调用;

一般情况下,我们最关心的只有messageReceived方法,接收消息并处理,然后调用IoSession的write方法发送出消息!(注意:这里接收到的消息都是Java对象,在IoFilter中所有二进制数据都被解码啦!)

一般情况下很少有人实现IoHandler接口,而是继承它的一个实现类IoHandlerAdapter,这样不用覆盖它的7个方法,只需要根据具体需求覆盖其中的几个方法就可以!

Iohandler的7个方法其实是根据session的4个状态值间变化来调用的:

Connected会话被创建并使用;


Idle会话在一段时间(可配置)内没有任何请求到达,进入空闲状态;


Closing会话将被关闭(剩余message将被强制flush);

Closed会话被关闭;

状态转换图如下:

Java NIO是相对于传统的IO操作而言的,因为提出了缓冲池等概念,使它的处理数据的效率大大提高;

多线程是并发处理的明智选择;为减少系统开销,线程池是并发应用中是经常使用的技术;

异步处理机制可以大大缩短每个请求的响应时间;

Mina2中就大量使用了这三项技术,使得它成为优秀的网络应用框架。

(Mina是Java NIO实现的应用框架,更倾向于短连接的服务。

服务端程序或客户端程序创建过程:创建连接——>添加消息过滤器(编码解码等)——>添加业务处理)

MINA学习汇总,布布扣,bubuko.com

时间: 2024-10-22 19:10:26

MINA学习汇总的相关文章

【Java,JNI】学习汇总

START FROM 2014/5/12 for memory of wenchuan [1]关于java内存的三篇文章: 1,内存模型http://www.cnblogs.com/aigongsi/archive/2012/04/26/2470296.html 而内存模型就是规定了一个规则,处理器如何同主内存同步数据的一个规则. 2,垃圾回收http://www.cnblogs.com/aigongsi/archive/2012/04/06/2434771.html 要点:jvm采用找root

【C++】学习汇总

[1]Virtual是C++ OO机制中很重要的一个关键字.只要是学过C++的人都知道在类Base中加了Virtual关键字的函数就是虚拟函数(例如下面例子中的函数print),于是在Base的派生类Derived中就可以通过重写虚拟函数来实现对基类虚拟函数的覆盖.当基类Base的指针point指向派生类Derived的对象时,对point的print函数的调用实际上是调用了Derived的print函数而不是Base的print函数.这是面向对象中的多态性的体现.(关于虚拟机制是如何实现的,参

Linux学习汇总——Linux程序管理,终端类型及命令获取帮助方式

本章Blog相关Linux知识点 计算机=硬件+软件 . 冯诺依曼理论,五大部件:CPU -- 运算器.控制器, 存储器,输入设备,输出设备. Shell 环境配置通过环境变量进行配置的 ,环境变量保存对应用程序的配置,在当前进程有效 .若长期有效,需保存到配置文件中. 语言分类: 解释型语言--写的程序在被执行之前,需要一个专门的编译过程,把程序编译成为机器语言的文件:编译型语言:解释性语言在运行程序的时候才翻译,效率比较低.两种方式只是翻译的时间不同 程序与进程的关系: 程序运行--进程启动

Linux学习汇总——Linux程序管理,终端类型及获取命令帮助方式

本章Blog相关Linux知识点 计算机=硬件+软件 . 冯诺依曼理论,五大部件:CPU -- 运算器.控制器, 存储器,输入设备,输出设备. Shell 环境配置通过环境变量进行配置的 ,环境变量保存对应用程序的配置,在当前进程有效 .若长期有效,需保存到配置文件中. 语言分类: 解释型语言--写的程序在被执行之前,需要一个专门的编译过程,把程序编译成为机器语言的文件:编译型语言:解释性语言在运行程序的时候才翻译,效率比较低.两种方式只是翻译的时间不同 程序与进程的关系: 程序运行--进程启动

HTTP头学习汇总

在开发http请求的时候,对HTTP头部信息一知半解,各种百度谷歌汇总一下学习到的资料. http简介 HTTP(HyperTextTransferProtocol)是超文本传输协议的缩写,它用于传送WWW方式的数据,关于HTTP 协议的详细内容请参考RFC2616.HTTP协议采用了请求/响应模型.客户端向服务器发送一个请求,请求头包含请求的方法.URI.协议版本.以及包含请求修饰符.客户信息和内容的类似于MIME的消息结构.服务器以一个状态行作为响应,相应的内容包括消息协议的版本,成功或者错

Hibernate学习汇总

一.Hibernate的基本原理 1.什么是Hibernate Hibernate,翻译过来是冬眠的意思,正好现在已经进入秋季,世间万物开始准备冬眠了.其实对于对象来说就是持久化. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的ORM框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库. Hibernate可以应用在任何使用JDBC的

Eucalyptus学习汇总

Elastic Utility Computing Architecture for Linking Your Programs To Useful Systems (Eucalyptus) 是一种开源的软件基础结构,用来通过计算集群或工作站群实现弹性的.实用的云计算.它最初是美国加利福尼亚大学 Santa Barbara 计算机科学学院的一个研究项目,现在已经商业化,发展成为了 Eucalyptus Systems Inc.不过,Eucalyptus 仍然按开源项目那样维护和开发. 以下主要针

mina学习(一)

Mina:是一个帮助用户开发高性能和高伸缩性网络应用程序的框架 学习地址链接:http://www.cnblogs.com/xuekyo/archive/2013/03/06/2945826.html http://my.oschina.net/chenleijava/blog/134170 流程: 创建服务器 ————服务器端业务逻辑————客户端 mima 核心包 :IoService,IoProcessor,Iohandler,IoAcceptor,IoConnector        .

ps(AI)快捷键学习汇总

PS快捷键汇总 Ctrl+O(open)打开   Ctrl+N(new) 新建  Ctrl+S 储存  Ctrl+shift+S 另存为    Ctrl+Delete 填充后景色 alt+delete 填充前景色 Ctrl+shift+alt+N 新建图层(俗称三键+N) Ctrl+D 取消选区   Ctrl+alt+Z撤销操作(20步)Ctrl+Z撤销一步 Ctrl+shift+Z回到上一步  Ctrl+G 成组 Ctrl+T调出自由变换工具/在文字编辑栏中也是调出文字面板的快捷键 Alt+s