java mina框架实例_MINA框架简介和一个简单的例子

基于MINA框架快速开发网络应用程序1.MINA框架简介MINA(MultipurposeInfrastructureforNetworkApplications)是用于开发高性能和高可用性的网络应用程序的基础框架。通过使用MINA框架可以可以省下处理底层I/O和线程并发等复杂工作,开发人员能够把更多的精力投入到业务设计和开发当中。MINA框架的应用比较广泛,应用的开源项目有Apache…

大家好,又见面了,我是你们的朋友全栈君。

基于MINA框架快速开发网络应用程序

1.MINA框架简介

MINA(Multipurpose Infrastructure for Network Applications)是用于开发高性能和高可用性的网络应用程序的基础框架。通过使用MINA框架可以可以省下处理底层I/O和线程并发等复杂工作,开发人员能够把更多的精力投入到业务设计和开发当中。MINA框架的应用比较广泛,应用的开源项目有Apache Directory、AsyncWeb、Apache Qpid、QuickFIX/J、Openfire、SubEthaSTMP、red5等。MINA框架当前稳定版本是1.1.6,最新的2.0版本目前已经发布了M1版本。

MINA框架的特点有:基于java NIO类库开发;采用非阻塞方式的异步传输;事件驱动;支持批量数据传输;支持TCP、UDP协议;控制反转的设计模式(支持Spring);采用优雅的松耦合架构;可灵活的加载过滤器机制;单元测试更容易实现;可自定义线程的数量,以提高运行于多处理器上的性能;采用回调的方式完成调用,线程的使用更容易。

2.MINA框架的常用类

类NioSocketAcceptor用于创建服务端监听;

类NioSocketConnector用于创建客户端连接;

类IoSession用来保存会话属性和发送消息;

类IoHandlerAdapter用于定义业务逻辑,常用的方法有:

方法 定义

sessionCreated() 当会话创建时被触发

sessionOpened() 当会话开始时被触发

sessionClosed() 当会话关闭时被触发

sessionIdle() 当会话空闲时被触发

exceptionCaught() 当接口中其他方法抛出异常未被捕获时触发此方法

messageRecieved() 当接收到消息后被触发

messageSent() 当发送消息后被触发

3.服务端应用开发示例

下面将以MINA2.0M1版本为基础,通过一个范例来演示一下如何使用MINA框架进行开发。开发环境为jdk6.0,开发工具NetBeans6.0,所需jar包slf4j-api.jar、slf4j-jdk14.jar、MINA-core-2.0.0-M1.jar。

首先定义一个业务逻辑处理器TimeServerHandler,继承自IoHandlerAdapter,实现的功能有:当客户端创建会话时会显示客户端设备的IP和端口;当客户端输入quit时结束会话;客户端输入其它内容时则向客户端发送当前时间。代码如下:

public class TimeServerHandler extends IoHandlerAdapter {

@Override

public void sessionCreated(IoSession session) {

// 显示客户端的ip和端口

System.out.println(session.getRemoteAddress().toString());

}

@Override

public void messageReceived(IoSession session, Object message)

throws Exception {

String str = message.toString();

System.out.println(“message=”+str);

if (str.trim().equalsIgnoreCase(“quit”)) {

session.close();// 结束会话

return;

}

Date date = new Date();

session.write(date.toString());// 返回当前时间的字符串

System.out.println(“Message written…”);

}

}

再定义一个类MinaTimeServer用来启动服务端:

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.setDefaultLocalAddress(new InetSocketAddress(PORT));// 设置端口号

acceptor.bind();// 启动监听

}

}

4.测试

首先运行MinaTimeServer,启动服务端,接着在命令行运行“telnet 127.0.0.1 9123”,来登录,这时会看到服务端输出如下:

2008-2-21 16:15:29 org.apache.MINA.filter.logging.LogLevel$4 log

/10.64.2.137:4140 IP和端口号

信息: CREATED

2008-2-21 16:15:29 org.apache.MINA.filter.logging.LogLevel$4 log

信息: OPENED 在客户端输入回车,在客户端可以看到服务端返回当前的时间:

Thu Feb 21 16:20:14 CST 2008

服务端输出:

2008-2-21 16:20:14 org.apache.MINA.filter.logging.LogLevel$4 log

信息: RECEIVED: HeapBuffer[pos=0 lim=2 cap=2048: 0D 0A] 接收收到回车符

Message written…

2008-2-21 16:20:14 org.apache.MINA.filter.logging.LogLevel$4 log

信息: SENT: HeapBuffer[pos=0 lim=29 cap=30: 54 68 75 20 46 65 62 20 32 31 20 31 36 3A 32 30…]

2008-2-21 16:20:14 org.apache.MINA.filter.logging.LogLevel$4 log

信息: SENT: HeapBuffer[pos=0 lim=0 cap=0: empty] 5.客户端开发示例

首先定义类TimeClientHandler来处理消息接收事件:

class TimeClientHandler extends IoHandlerAdapter {

public TimeClientHandler() {

}

@Override

public void messageReceived(IoSession session, Object message)

throws Exception {

System.out.println(“message=” + message);// 显示接收到的消息

}

}

接着定义MinaTimeClient类用于连接服务端,并向服务端发送消息:

public class MinaTimeClient {

public static void main(String[] args) {

// 创建客户端连接器.

NioSocketConnector connector = new NioSocketConnector();

connector.getFilterChain().addLast(“logger”, new LoggingFilter());

connector.getFilterChain().addLast(“codec”,new ProtocolCodecFilter(new TextLineCodecFactory(Charset.forName(“UTF-8”)))); // 设置编码过滤器

connector.setConnectTimeout(30);

connector.setHandler(new TimeClientHandler());// 设置事件处理器

ConnectFuture cf = connector.connect(new InetSocketAddress(“127.0.0.1”,9123));// 建立连接

cf.awaitUninterruptibly();// 等待连接创建完成

cf.getSession().write(“hello”);// 发送消息

cf.getSession().write(“quit”);// 发送消息

cf.getSession().getCloseFuture().awaitUninterruptibly();// 等待连接断开

connector.dispose();

}

}

6.总结

通过上述示例可以了解到:使用MINA框架来开发的网络应用程序代码结构更清晰;MINA框架完成了底层的线程管理;MINA内置的编码器可以满足大多数用户的需求,省去了开发人员消息编码解码的工作。具称使用MINA开发服务器程序的性能已经逼近使用 C/C++ 语言开发的网络服务。因此,建议在网络应用程序开发过程中尝试使用MINA框架来提高我们的开发效率和应用程序的执行效率。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/127309.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 舆情监测分析系统_舆情监测系统

    舆情监测分析系统_舆情监测系统一、引言1.1目的  编写此文档的目的是确认舆情分析系统的需求及系统边界,指导系统的设计。1.2项目信息项目名称:舆情分析系统项目提出者:指导教师开发者:东北大学软件学院大数据班T09实训项目组(lzf、lcx)用户:舆情分析员、系统管理员1.3缩写说明1.4术语定义1.5参考资料新浪舆情通:https://yqt.mdata.net/二、舆情分析系统概述2.1舆情分析系统介绍  我们的舆情分析系统主要包括舆情总缆分析、舆情搜索、文章分析、文章评论分析、事件

    2022年9月14日
    2
  • Advanced System Care官方下载(附激活码)

    Advanced System Care官方下载(附激活码)iobit公司出品的一款系统辅助工具AdvancedSystemCare,它通过对系统全方位的诊断,找到系统性能的瓶颈所在,并将测试结果显示出来。针对系统的瓶颈对其优化,提高效率发挥最大的性能,通过优化后系统性能和网络速度都会有明显提升包含基本功能,注册表清理,垃圾文件清理等。现今系统清理,系统优化工具满天飞,可是很少有对系统全方位的诊断,找到系统性能的瓶颈所在,然后有针对性地进行修改、优化…

    2022年10月20日
    2
  • Latex中插图总结(一)

    Latex中插图总结(一)写在前面的话CSDN中的数据库保存是不是有问题,我之前写了很多的,存在草稿箱里的最后竟然没有在了。真是郁闷死个人。亏我写了这么多,以后写完要保存了。泪目。Latex的插图在Latex中使用插图一般有两种方式,一种是插入事先准备好的图片,另一种是使用Latex代码直接在文档中画图。我们一般常见的使用都是第一种,准备好图片,然后直接插入在我们文档当中。只有一些特殊情况需要用大量代码作图。插图功能不是有L

    2022年6月10日
    44
  • 用python编写猴子吃桃问题_python猴子吃桃三种解法

    用python编写猴子吃桃问题_python猴子吃桃三种解法人工智能课内实验报告(8次)学院:自动化学院班级:智能1501姓名:刘少鹏(34)学号:目录课内实验1:猴子摘香蕉问题的VC编程实现……………………1课内实验2:编程实现简单动物识别系统的知识表示………5课内实验3:盲目搜索求解8数码问题………………………18课内实验4:回溯算法求解四皇后问题………………………33课内实验5:编程实现一…

    2022年9月26日
    2
  • 什么是跨域?如何解决?

    什么是跨域?如何解决?一、什么是跨域?跨域:指的是浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对javascript施加的安全限制。例如:a页面想获取b页面资源,如果a、b页面的协议、域名、端口、子域名不同,所进行的访问行动都是跨域的,而浏览器为了安全问题一般都限制了跨域访问,也就是不允许跨域请求资源。注意:跨域限制访问,其实是浏览器的限制。理解这一点很重要!!!同源策略:是指协议,域名,端口都要相同,其中有一个不同都会产生跨域;二、跨域访问示例假设有两个网站,A网站部署在:.

    2022年5月20日
    51
  • 在线作图|2分钟做Lefse分析「建议收藏」

    在线作图|2分钟做Lefse分析「建议收藏」​Lefse分析Lefse(LDAEffectSize)分析是一种用于发现和解释高维度数据的基因、通路和分类单元相关等生物标识的分析工具,通常可以进行两个或多个分组的比较,能够找出组与组之间有差异的生物标识。在微生物多样性分析中,Lefse可用来分析微生物的组间差异,如菌群差异等等。TUTUCLOUD云平台提供在线做Lefse分析的工具,可获得LDA值分布柱状图以及特征表。TUTU网站工具使用小编给大家介绍一个在线作图工具,lefse分析方法如下:①登录网址:www.cloudtutu.com

    2022年4月30日
    76

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号