NIO不错的
来源:互联网 发布:如何阅读java源代码 编辑:程序博客网 时间:2024/05/20 13:15
欢迎大家讨论,我也是接触时间不长,有问题欢迎大家指正。欢迎转载,转载请注明出处
楔子
最近在研究JAVA NIO的相关知识,发现网上多是三种类型的研究文章,一是单Reactor单Selector,二是主从Reactor单Selector,三就是无Reactor单Selector,有一篇是一个Selector绑定两个地址的文章。但是随着链接数增多,单Selector肯定不能满足对于系统性能的要求,所以必然会出现多个selector配合工作的情况。可是我找了很久,也只找到一篇讨论Mina和Grizzly的多selector的实现,并没有自己去实现一个简单的多selector的例子(文章地址:点击打开链接)。这些天闲来无事,写成一个多selector配合工作的例子,与大家共享。本实例只是关注如何进行多selector配合工作,例子有很多不完美的地方,比如对于包拆分和包合并的判断处理还没有实现,如果错误之处,还请大家指正。
背景
直接来。最基本的Java NIO流程图,如下:
我们知道,如果连接数增多,并且读写量很大,那么服务器的压力会非常大。于是大师们研究出使用reactor模式来搞定。于是出现了下面的实现:
(图片来源:点击打开链接)
Reactor负责Select,如果发现是OP_ACCEPT,则交给acceptor处理,如果发现是读写,则交给Thread Pool来处理。读写新开了线程,不会阻塞整个主线程的运行。我们今天的例子就是从这个架构发展而来。
实例
多selector,顾名思义,多个selector来配合完成NIO的操作。这样做的好处是可以最大限度的榨取服务器的资源。我们使用一个selector来处理accept的工作,完成绑定,监听,一个selector完成读写,发送的工作。我们称这个版本为V1.1。
首先来看Server.Java,这是Server端main函数的所在地,代码如下:
来自CODE的代码片Server.java
来看ServerReactor.java:
来自CODE的代码片ServerReactor.java
来自CODE的代码片ServerDispatcher.java
来自CODE的代码片SocketHandler.java
大家看到这里,就会比较清楚了,每一个线程启动后,都会调用selector.selectNow方法来监听SelectionKey,找到了以后,就会进行处理。可是怎么叫accept处理OP_ACCEPT, read处理OP_READ,Write处理OP_WRITE呢。我都是放到了具体的子类的runnerExecute里面进行判断。
来自CODE的代码片SocketAcceptHandler.java
来自CODE的代码片SocketReadHandler.java
来自CODE的代码片SocketWriteHandler.java
扩展
首先,可以将Read和Write的Selector分开,这样理论上会更快,但是会出现一个问题。那就是服务器处理完OP_ACCEPT和第一次的read之后,就会一直处理写,直到接收到客户端的数据才开始读,这样客户端读取的东西就是错误的。我们需要加一个变量来控制,如果上一次是写,那么必须处理完读之后,才能开始第二次的写。
其次,我们可以改造ServerDispatcher,现在维护的是3个selector,其实,应该维护3个SocketHandler,每个Handler里面自己创建新的selector,或者维护两个SocketHandler,一个accept,一个Read/Write,那么这就是什么的架构?这就是Grizzly的核心架构。如果我们维护两个线程池,第一个池子里面 只有一个线程--accept,第二个池子里面,放入读写的Handler,那么这就是Mina或者是Netty的基础架构。对于Netty来说,accept就是父类的handler,读写Handler就是子类的handler。
参考及代码
代码地址:https://github.com/JJZHK/NIOPractice.git
参考了以下图书及文章:
1. 《Netty权威指南》
2.http://www.iteye.com/topic/482269
3.http://blog.csdn.net/thomescai/article/details/6865406
0 0
- NIO不错的
- 不错的java nio入门
- ~~~~~不错的
- 不错的
- nio的
- 小米狼子的野心~~~不错不错!
- Java NIO(1): 迟迟登场的NIO
- Java NIO(1):迟迟登场的NIO
- Java NIO(1):迟迟登场的NIO
- 【NIO】更简单的nio使用方式
- Java NIO:IO与NIO的区别
- NIO学习二、NIO的基本使用
- Java NIO:IO与NIO的区别
- 做的不错
- 一个不错的计数器
- 不错的Python社区
- 一个不错的效果
- 不错的站点
- 产品的“服务”和“特性”
- memcached 命中率问题 分析
- 工作之杂记--JS杂记
- MAC - 安装lnmp开发环境
- WEB开发中的会话控制
- NIO不错的
- 行人检测 opencv
- poj 3468 A Simple Problem with Integers(线段树,lazy思想 经典题)
- Juce源码分析(六)弱引用(1)引用计数对象与引用计数对象指针
- 【v2.x OGE-example 第二节】 实体参数
- module
- jquery表格动态增删改及取数据绑定数据完整方案
- cocos2d-x如何截屏并保存图片
- phony 详解