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(); 
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);//显示接收到的消息 


接着定义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框架来提高我们的开发效率和应用程序的执行效率。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
众所周知,人工智能是当前最热门的话题之一, 计算机技术与互联网技术的快速发展更是将对人工智能的研究推向一个新的高潮。 人工智能是研究模拟和扩展人类智能的理论与方法及其应用的一门新兴技术科学。 作为人工智能核心研究领域之一的机器学习, 其研究动机是为了使计算机系统具有人的学习能力以实现人工智能。 那么, 什么是机器学习呢? 机器学习 (Machine Learning) 是对研究问题进行模型假设,利用计算机从训练数据中学习得到模型参数,并最终对数据进行预测和分析的一门学科。 机器学习的用途 机器学习是一种通用的数据处理技术,其包含了大量的学习算法。不同的学习算法在不同的行业及应用中能够表现出不同的性能和优势。目前,机器学习已成功地应用于下列领域: 互联网领域----语音识别、搜索引擎、语言翻译、垃圾邮件过滤、自然语言处理等 生物领域----基因序列分析、DNA 序列预测、蛋白质结构预测等 自动化领域----人脸识别、无人驾驶技术、图像处理、信号处理等 金融领域----证券市场分析、信用卡欺诈检测等 医学领域----疾病鉴别/诊断、流行病爆发预测等 刑侦领域----潜在犯罪识别与预测、模拟人工智能侦探等 新闻领域----新闻推荐系统等 游戏领域----游戏战略规划等 从上述所列举的应用可知,机器学习正在成为各行各业都会经常使用到的分析工具,尤其是在各领域数据量爆炸的今天,各行业都希望通过数据处理与分析手段,得到数据中有价值的信息,以便明确客户的需求和指引企业的发展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值