- 1、本文档共18页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MINA官方教程(中文版)
简介:ApacheMINA2 是一个开发高性能和高可伸缩性网络应用程序的网络应用框架。它提供了
一个抽象的事件驱动的异步 API,可以使用 TCP/IP、UDP/IP、串口和虚拟机内部的管道等传输方
式。ApacheMINA2 可以作为开发网络应用程序的一个良好基础。本文将介绍 ApacheMINA2 的
基本概念和 API,包括 I/O 服务、I/O 会话、I/O 过滤器和 I/O 处理器。另外还将介绍如何使用状
态机。本文包含简单的计算器服务和复杂的联机游戏两个示例应用。
ApacheMINA2 是一个开发高性能和高可伸缩性网络应用程序的网络应用框架。它提供了一个抽象
的事件驱动的异步 API,可以使用 TCP/IP、UDP/IP、串口和虚拟机内部的管道等传输方式。Apache
MINA2 可以作为开发网络应用程序的一个良好基础。下面将首先简单介绍一下 Apache MINA2。
Apache MINA2 介绍
Apache MINA 是 Apache 基金会的一个开源项目,目前最新的版本是 2.0.0-RC1。本文中使用的
版本是 2.0.0-M6。从参考资料中可以找到相关的下载信息。下面首先介绍基于 Apache MINA 的网
络应用的一般架构。
基于 Apache MINA 的网络应用的架构
基于 Apache MINA 开发的网络应用,有着相似的架构。图 1中给出了架构的示意图。
图 1. 基于 Apache MINA 的网络应用的架构
如图 1所示,基于 ApacheMINA 的网络应用有三个层次,分别是 I/O 服务、I/O 过滤器和 I/O 处
理器:
I/O 服务:I/O 服务用来执行实际的 I/O 操作。Apache MINA 已经提供了一系列支持不同
协议的 I/O 服务,如 TCP/IP、UDP/IP、串口和虚拟机内部的管道等。开发人员也可以实
现自己的 I/O 服务。
I/O 过滤器:I/O 服务能够传输的是字节流,而上层应用需要的是特定的对象与数据结构。
I/O 过滤器用来完成这两者之间的转换。I/O 过滤器的另外一个重要作用是对输入输出的数
据进行处理,满足横切的需求。多个 I/O 过滤器串联起来,形成 I/O 过滤器链。
I/O 处理器:I/O 处理器用来执行具体的业务逻辑。对接收到的消息执行特定的处理。
创建一个完整的基于 Apache MINA 的网络应用,需要分别构建这三个层次。Apache MINA 已经
为 I/O 服务和 I/O 过滤器提供了不少的实现,因此这两个层次在大多数情况下可以使用已有的实
现。I/O 处理器由于是与具体的业务相关的,一般来说都是需要自己来实现的。
事件驱动的 API
Apache MINA 提供的是事件驱动的 API。它把与网络相关的各种活动抽象成事件。网络应用只需
要对其感兴趣的事件进行处理即可。事件驱动的 API 使得基于 Apache MINA 开发网络应用变得
比较简单。应用不需要考虑与底层传输相关的具体细节,而只需要处理抽象的 I/O 事件。比如在实
现一个服务端应用的时候,如果有新的连接进来,I/O 服务会产生sessionOpened这样一个
件。如果该应用需要在有连接打开的时候,执行某些特定的操作,只需要在 I/O 处理器中此事件处
理方法sessionOpened中添加相应的代码即可。
在介绍 Apache MINA 中的基本概念的细节之前,首先通过一个简单的应用来熟悉上面提到的三个
层次的具体职责。
回页首
从简单应用开始
在使用 Apache MINA 开发复杂的应用之前,首先将介绍一个简单的应用。通过此应用可以熟悉上
面提到的三个层次,即 I/O 服务、I/O 过滤器和 I/O 处理器。该应用是一个简单的计算器服务,客
户端发送要计算的表达式给服务器,服务器返回计算结果。比如客户端发送2+2,服务器返回4.0
作为结果。
在实现此计算器的时候,首先需要考虑的是 I/O 服务。该计算器使用 TCP/IP 协议,需要在指定端
口监听,接受客户端的连接。ApacheMINA 提供了基于 JavaNIO 的套接字实现,可以直接使用。
其次要考虑的是 I/O 过滤器。I/O 过滤器过滤所有的 I/O 事件和请求,可以用来处理横切的需求,
如记录日志、压缩等。最后就是 I/O 处理器。I/O 处理
您可能关注的文档
- Linux as4下 oracle9的安装.doc
- 第4章 建设项目设计阶段工程造价计价和控制.ppt
- 第12讲:自然历史中生命瑰宝:有机宝石(珊瑚、琥珀、象牙等).ppt
- 第一章 法律调整经济关系一般理论.ppt
- 第8讲 酶本质、特性和相关实验探究.ppt
- 第9讲 差分模型求解.ppt
- 第一章第二节原子结构和元素性质第一课时.ppt
- linux_讲义.pdf
- 第七单元 课题2 燃料合理利用和开发.ppt
- 第七章 城镇居住区规划和设计.ppt
- DB44_T 2611-2025 城市排水管网有毒有害气体监测与风险分级管理技术标准.pdf
- DB44_T 2612-2025 竞赛类科普活动策划与实施服务规范.pdf
- DB43_T 2947-2024 烟草种子质量控制规程.pdf
- DB37_T 4836-2025 煤矿风量实时监测技术要求.pdf
- 叉车防撞系统,全球前22强生产商排名及市场份额(by QYResearch).docx
- 超滤膜,全球前18强生产商排名及市场份额(by QYResearch).docx
- DB62T 4172-2020 玉米品种 酒623规范.pdf
- DB62T 4160-2020 在用真空绝热深冷压力容器综合性能在线检测方法.pdf
- DB62T 4164-2020 辣椒品种 酒椒1号.pdf
- DB62T 4133-2020 公路隧道地质超前预报机械能无损探测技术规程.pdf
文档评论(0)