`
k_lb
  • 浏览: 798854 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论
  • kitleer: 据我所知,国内有款ETL调度监控工具TaskCTL,支持ket ...
    kettle调度

apache mina 学习(三)-----Mina架构

 
阅读更多

mina的架构图:


说明了mina是介于用户业务和底层的socket之间的中间层


下面是详细的架构:

I/O Service扮演实际的IO角色

I/O Filter Chain 在输入和输出的io流中进行过滤

I/O Handler 业务逻辑实现

根据以上的信息可以知道,要创建一个mina的应该一般分三步:

1、选择一个已经存在的I/O Service(一般叫XXAcceptor),当让也可以创建一个自定义的

2、选择或是自定义一些Filters,用户处理双向的io流

3、在Handler接口的实现类中定义自己的业务方法




Mina客户端的架构:


客户端首先创建一个IOConnector 用来和服务端通信,顾名思义这就是建立的一个连接对象,然后在这个连接上创建一个session,

我们的客户端中的业务方法可以向session中写入数据,数据经过Filter Chain的过滤后会发送给服务端,从服务端发回的数据也会首先经过Filter Chain的过滤,然后交给IOHandler做进一步的处理。


mina服务端架构:


IOAcceptor 监听来自网络的连接请求,如果有一个新的请求(也就是Connection),mina会建立一个新的Connection,并在它之中建立一个session,所有来自这个ip和端口的请求都由这个session来处理,然后经过特定的Filter Chain解析,在这些Filter中我们可以定义一些转换,编码、解码等等的功能负责把底层传输的对象拼装为更高一层的对象方便后续的处理,最后传输的数据被交给IOHandler,我们的业务方法可以实现IOHandler接口来获得传输的数据,做最后的业务处理,发送数据亦然。
分享到:
评论

相关推荐

    apache mina帮助文档

    NIO是一个基于事件的IO架构,最基本的思想就是:有事件我通知你,你再去做你的事情,没事件时你大可以节约大把时间去做其它任何事情。而且NIO的主线程only one,不像传统的模型,需要N个线程去,也减轻了JVM的工作量...

    使用 Apache MINA 开发高性能网络应用程序

    本文将通过一个简单的问候程序 HelloServer 来介绍 MINA 的基础架构的同时演示如何使用 MINA 开发网络应用程序。

    mina实例、资源包、学习文档

    最近使用Mina开发一个Java的NIO服务端程序,因此也特意学习了Apache的这个Mina框架。 首先,Mina是个什么东西?看下官方网站(http://mina.apache.org/)对它的解释: Apache的Mina(Multipurpose Infrastructure ...

    mina2.0初学教程

    最近使用Mina开发一个Java的NIO服务端程序,因此也特意学习了Apache的这个Mina框架。 首先,Mina是个什么东西?看下官方网站(http://mina.apache.org/)对它的解释: Apache的Mina(Multipurpose Infrastructure ...

    MINA通讯框架的两个简单实例和文档

    Apache的Mina(Multipurpose Infrastructure Networked Applications)是一个网络应用框架,可以帮助用户开发高性能和高扩展性的网络应用程序;它提供了一个抽象的、事件驱动的异步API,使Java NIO在各种传输协议...

    Apache+Mina入门基础

    mina是一种高效的互联网网络通信架构,此资料为入门基础。

    mina2框架+项目实例教程

    一个网络应用框架,可以帮助用户开发高性能和高扩展性的网络应用程序;它提供了一个抽象的、事件...Apache Mina也称为:  NIO框架  客户端/服务端框架(典型的C/S架构)  网络套接字(networking socket)类库

    Mina消息发送简单实现

    基于Mina的网络通讯,分为服务端和客户端。...研究selector NIO实现时,发现了这个架构。 Mina的底层实现实际就是selector和SocketChannel。所以如果对Mina源码感兴趣的可以先去看下selector相关的例子。

    mina高性能Java网络框架.rar

    Apache的Mina(Multipurpose Infrastructure Networked Applications)是一个网络应用框架,可以帮助用户开发高性能和高扩展性的网络应用程序;它提供了一个抽象的、事件驱动的异步API,使Java NIO在各种传输协议...

    Android C/S结构代码

    基于apache mina框架的C/S结构代码,包含图片传输代码

    物联网上位机平台

    服务端基于Apache MINA设计开发,可自由切换TCP、UDP通讯方式;支持工业控制中的MODBUS、RS485、RS232、自定义TCP协议等。 采用优雅的松耦合架构设计; 支持多编解码功能,各协议组件相互独立; 支持协议解析...

    java开源包1

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    java开源包10

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    JAVA上百实例源码以及开源项目源代码

     Java数据压缩与传输实例,可以学习一下实例化套按字、得到文件输入流、压缩输入流、文件输出流、实例化缓冲区、写入数据到文件、关闭输入流、关闭套接字关闭输出流、输出错误信息等Java编程小技巧。 Java数组倒置...

    java开源包11

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    java开源包2

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    java开源包3

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    java开源包6

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

    java开源包5

    6、支持多种通信框架(Mina/Netty/Grizzly),支持多种序列化/反序列化(Java/Hessian/PB); 7、支持自定义通信协议,可完全替换NFS-RPC自带的协议。 淘宝开放平台JAVA版SDK top4java 设计原则 容易维护扩展(不...

Global site tag (gtag.js) - Google Analytics