`

Yet another nio framework for java

    博客分类:
  • java
阅读更多

项目名称:Yanf4j(Yet another nio framework for java)
项目地址:http://code.google.com/p/yanf4j/ ,当前版本0.30-beta1
协议:Apache License, Version 2.0
简单描述:
    有这么多nio框架了,为什么要another?重复造轮子也罢,这框架脱胎于一个服务器项目的网络层代码,期间参考了cindy、grizzly等nio框架的实现,加上自己的一些心得体会实现的。特点是简单、小巧、超轻量级。项目没有多大野心,目标是高效、简单地实现非阻塞模式的Server(TCP、UDP)并且保证不错的性能要求,不提供客户端API 和阻塞模式。如果你的项目需要实现一个socket server并且不希望用太重量级的框架,yanf4j是个不错的选择。

    例子,在source archive中带有例子,这里描述下tcp和udp的echo server的实现。
 一、先看TCP的Echo Server
1、实现处理handler,继承HandlerAdapter类,实现相应的回调方法,这与其他nio框架没啥区别:

<!---->import  com.google.code.yanf4j.nio.Dispatcher;
import  com.google.code.yanf4j.nio.Session;
import  com.google.code.yanf4j.nio.impl.HandlerAdapter;
import  com.google.code.yanf4j.nio.util.DispatcherFactory;

public   class  EchoHandler  extends  HandlerAdapter < String >  {

    Dispatcher dispatcher 
=  DispatcherFactory.newDispatcher( 4 );

    @Override
    
public   void  onException(Session session, Throwable t) {
        t.printStackTrace();
    }

    @Override
    
public   void  onMessageSent(Session session, String t) {
         System.out.println( " sent  "   +  t  +   "  to  "
                    
+  session.getRemoteSocketAddress());
    }

    @Override
    
public   void  onSessionStarted(Session session) {
        System.out.println( " session started " );
        session.setUseBlockingRead(
true );
        session.setUseBlockingWrite(
false );
    }

    
public   void  onSessionCreated(Session session) {
         System.out.println(session.getRemoteSocketAddress().toString()
                    
+   "  connected " );
    }

    
public   void  onSessionClosed(Session session) {
         System.out.println(session.getRemoteSocketAddress().toString()
                    
+   "  disconnected " );

    }

    
public   void  onReceive( final  Session session,  final  String msg) {
         System.out.println( " recv: "   +  msg);
        
if  (msg  !=   null )
            dispatcher.dispatch(
new  Runnable() {
                
public   void  run() {

                    
if  (msg.equals( " q " ))
                        session.close();
                    session.send(msg);
                }
            });
    }

}



2、实现EchoServer,核心是TCPController类的使用:

<!---->        Configuration configuration  =   new  Configuration();
        configuration.setStatisticsServer(
true );
        configuration.setTcpSessionReadBufferSize(
256   *   1024 );  //  设置读的缓冲区大小
        AbstractController controller  =   new  TCPController(configuration,
                
new  StringCodecFactory());
        controller.setPort(
8080 );  //  设置端口
        controller.setReadThreadCount( 1 );  //  设置读线程数,通常为1
        controller.setReceiveBufferSize( 16   *   1024 );  //  设置socket接收缓冲区大小
        controller.setReuseAddress( false );  //  设置是否重用端口
        controller.setHandler( new  EchoHandler());  //  设置handler
        controller.setHandleReadWriteConcurrently( true );  //  设置是否允许读写并发处理
        controller.addStateListener( new  ServerStateListener());
        controller.start();


Configuration 默认会在classpath查找yanf4j.properties属性文件,用于配置服务器属性,然而,你也看到,可以编码设置这些属性,具体参考wiki。

3、然后?没然后了,一个TCP的echo server已经搞定了,你可以telnet到8080端口试试了。

二、UDP的Echo server
1、handler,可以复用前面的EchoHandler
2、UDP的核心类是UDPController:

<!---->        Configuration configuration  =   new  Configuration();
        configuration.setTcpPort(
8090 );
        configuration.setTcpReuseAddress(
false );
        configuration.setStatisticsServer(
true );
        configuration.setTcpNoDelay(
true );
        configuration.setTcpReadThreadCount(
1 );
        configuration.setTcpRecvBufferSize(
16   *   1024 );
        UDPController controller 
=   new  UDPController(configuration);
        controller.setMaxDatagramPacketLength(
1024 );
        controller.setHandler(
new  EchoHandler());
        controller.start();


  更多细节,请参考项目主页上的wiki。

分享到:
评论
1 楼 rain2005 2009-08-25  
这么好的东东啊,正在学习中,以后碰到问题还请帮忙解答下啊。

相关推荐

    java NIO和java并发编程的书籍

    java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java...

    淘宝gecko框架设计.pdf

    Gecko基于yanf4j(Yet another nio framework for java)构建,这是一个Reactor+Handler模式的NIO框架。框架的主要组件包括: - **Controller**:控制接口,负责启动、管理、停止框架,并与业务代码交互。 - **...

    java NIO.zip

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统的I/O模型的新技术。自Java 1.4版本引入NIO后,它为Java开发者提供了更高效的数据传输方式,尤其是在处理大量并发...

    NioServer.java

    NioServer.java

    java NIO实例

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从1.4版本开始引入的一种新的I/O模型,它为Java应用程序提供了更高效的数据传输方式。传统的Java I/O模型(BIO)在处理大量并发连接时效率较...

    Java.NIO资源下载资源下载

    根据提供的文件信息,我们可以提取并总结出关于Java NIO(New Input/Output)的重要知识点。 ### Java NIO 概述 Java NIO 是 Java 平台的一个重要特性,首次出现在 Java 1.4 版本中。它为 Java 开发者提供了一套...

    nio.rar_NIO_java nio_java_nio_mina java n

    Java NIO(New Input/Output)是Java标准库中提供的一种I/O模型,与传统的 Blocking I/O(BIO)相比,NIO具有更高的性能和更好的灵活性。NIO在Java 1.4版本中引入,其核心是Channel、Buffer和Selector三大组件。下面...

    Java NIO英文高清原版

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java平台中用于替代标准I/O(BIO)模型的一种新机制。NIO在Java 1.4版本引入,提供了更高效的数据处理和通道通信方式,特别适用于高并发、大数据...

    Java NIO 中文 Java NIO 中文 Java NIO 中文文档

    Java NIO 深入探讨了 1.4 版的 I/O 新特性,并告诉您如何使用这些特性来极大地提升您所写的 Java 代码的执行效率。这本小册子就程序员所面临的有代表性的 I/O 问题作了详尽阐述,并讲解了 如何才能充分利用新的 I/O ...

    JavaNIO.zip_java nio_nio java

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从1.4版本开始引入的一个新特性,旨在提供一种更高效、更具选择性的I/O操作方式。相较于传统的IO模型,NIO的核心优势在于其非阻塞特性,允许...

    JavaNIO chm帮助文档

    Java NIO系列教程(一) Java NIO 概述 Java NIO系列教程(二) Channel Java NIO系列教程(三) Buffer Java NIO系列教程(四) Scatter/Gather Java NIO系列教程(五) 通道之间的数据传输 Java NIO系列教程(六)...

    nio.rar_NIO_NIO-socket_java nio_java 实例_java.nio

    Java NIO(New IO)是Java 1.4版本引入的一个新特性,它为Java应用程序提供了非阻塞I/O操作的能力,与传统的IO模型(基于流的I/O和基于缓冲区的I/O)相比,NIO具有更高的效率和灵活性。在Java NIO中,数据是以通道...

    java基于NIO实现Reactor模型源码.zip

    java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现Reactor模型源码java基于NIO实现...

    nio.zip_NIO_NewIO_NIO.c_java NIO chm_java nio

    NIO(New IO)是Java平台中用于处理输入/输出操作的一种高级API,它在Java 1.4版本中引入,以替代传统的IO流模型。NIO提供了更高效、更灵活的数据传输方式,尤其适用于高并发和大数据量的场景。 在Java的NIO体系中...

    Java NIO Socket基本

    Java NIO(New Input/Output)是Java标准库中提供的一种I/O模型,与传统的 Blocking I/O(同步阻塞I/O)相对。NIO在Java 1.4版本引入,其设计目标是提供一种更高效、更灵活的I/O操作方式,特别适合处理大量并发连接...

    Java Nio selector例程

    java侧起server(NioUdpServer1.java),基于Java Nio的selector 阻塞等候,一个android app(NioUdpClient1文件夹)和一个java程序(UI.java)作为两个client分别向该server发数据,server收到后分别打印收到的消息...

    java nio 实现socket

    ### Java NIO 实现Socket通信详解 #### 一、NIO与传统IO的区别及优势 在探讨如何使用Java NIO实现Socket通信之前,我们需要先理解NIO(Non-blocking I/O,非阻塞I/O)与传统阻塞I/O之间的区别。 **传统阻塞I/O...

    JavaNIO服务器实例Java开发Java经验技巧共6页

    Java NIO(Non-blocking Input/Output)是Java平台中用于替代标准I/O(Blocking I/O)的一种机制。在Java NIO出现之前,传统的Java I/O基于流和套接字的模型是阻塞的,即一个线程在等待数据读取或写入时会被阻塞,...

    java NIO技巧及原理

    Java NIO(New Input/Output)是Java标准库提供的一种I/O模型,它与传统的 Blocking I/O(IO)相比,提供了更加高效的数据传输方式。在Java NIO中,"新"主要体现在非阻塞和多路复用这两个特性上,这使得NIO更适合于...

    Java NIO——Java NIO

    Java NIO——Java NIO——Java NIO

Global site tag (gtag.js) - Google Analytics