tomcat9源码分析(五)--NIO

一、java nio介绍

    java nio全称java non-blocking IO是jdk1.4以后java新增的非阻塞io,完全可以替代之前的阻塞io。

    1.原理及实现

     java nio采用reactor(反应器)模式,使用单线程模拟多线程,节省系统线程创建和线程上下文切换所需要的系统资源消耗。增 加了系统吞吐量。nio包含重要概念 通道、缓冲区、选择器。

   通道和缓冲区(Channels and Buffers):标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(Buffer)进行操作,数据总是从通道读取到缓冲区中,或者从缓冲区写入到通道中。

    通道类型: FileChannel:从文件中读写数据。   DatagramChannel:能通过UDP读写网络中的数据。  SocketChannel:能通过TCP读写网络中的数据。ServerSocketChannel:可以监听新进来的TCP连接,像Web服务器那样。对每一个新进来的连接都会创建一个 SocketChannel。FileChannel比较特殊,它可以与通道进行数据交互, 不能切换到非阻塞模式,套接字通道可以切换到非阻塞模式;

    缓冲区 : 本质上是一块可以存储数据的内存,被封装成了buffer对象而已!缓冲区类型:ByteBufferMappedByteBuffer CharBufferDoubleBufferFloatBufferIntBufferLongBufferShortBuffer

    选择器:相当于一个观察者,用来监听通道感兴趣的事件,一个选择器可以绑定多个通道;

二、tomcat9中的nio使用

    tomcat8之后去掉原来tomcat中支持的bio模式。只支持nio(非阻塞io)和apr(操作系统级别的异步io)模式。说明tomcat开发者认为现在nio的性能在大多数情况下已经至少不低于bio(阻塞io)。之前网上有很多测试在连接数小于1000的时候tomcat的nio模式没有明显的性能提升,甚至还略低于传统的bio模式。这是因为nio优化的性能在线程的资源占用和上下文切换上。如果连接数较少,这种优化就无法体现。在大并发,传统模式需要超多线程的情况下,nio模式的性能才有明显提高。下面我就来总结下tomcat9中nio的实现和使用。

    tomcat9中nio的使用主要逻辑在NioEndpoint这个类中。主要有 Acceptor、Poller、SocketProcessor、Excutor等组件参与。来看下他们是如何来实现连接的接入的吧!

    首先从Connector这个类来说起,这个类是用来处理连接的。

Connector的StartInternal方法

这是这个组件的启动方法,继续看下protocolHandler.start()这个方法里面。protocolHandler是具体的协议处理器。这里默认应该是http1.1的协议处理器。

protocolHandler.start()方法

这个方法里面首先启动了NioEndPoint组件。然后启动一个超时时间守护线程。这个线程我没有仔细去看应该是监测异步请求的超时。应该属于http协议的实现部分,暂不做关注,直接进入endpoint.start()方法。

endpoint.start()方法

继续看下startInternal方法这个方法在具体的实现类中,这里我们看下Nioendpoint的startInternal方法。

Nioendpoint的startInternal方法

看下startAcceptorThreads方法

startAcceptorThreads方法

开始接收请求。那么是如何接受请求的呢。我们进去其中一个AcceptorThreads中看看。我们看下这这个thread中的run方法都干了什么

AcceptorThreads中主要代码

我们看到,AcceptorThreads中主要是先获取了一个链接,然后调用endpoint的setSocketOptions方法,我们看看setSocketOptions方法里都干了什么。


endpoint 的setSocketOptions 方法 

我们看到setSocketOptions 方法首先包装了下channel,然后就把channel注册进了poller里。那poller是如何监听的channel的呢。我们来看下poller的构建及运行。首先我们看下poller的构建方法。


poller的构造方法

可以看出来poller只是对java nio包中selector进行了一个包装。调用poller构造方法时。实际上构造了一个selector.我们再来看看注册方法执行了什么?

poller的注册方法

poller的注册方法只是对socket的channle做了一层封装,然后就注册一个事件。所以tomcat 和javanio相似只是包装了一层哈。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容

  • # Java NIO # Java NIO属于非阻塞IO,这是与传统IO最本质的区别。传统IO包括socket和文...
    Teddy_b阅读 589评论 0 0
  • 简介 Java NIO 是由 Java 1.4 引进的异步 IO.Java NIO 由以下几个核心部分组成: Ch...
    永顺阅读 1,791评论 0 15
  • Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java I...
    JackChen1024阅读 7,555评论 1 143
  • 一、基本概念描述 1.1 I/O简介 I/O即输入输出,是计算机与外界世界的一个借口。IO操作的实际主题是操作系统...
    4ea0af17fd67阅读 407评论 0 0
  • 在Client上操作 新建rbd块 查看块设备 查看块设备(映像)信息 将rbd块映射到主机 格式化 挂载 删除 ...
    竹莲心龙阅读 1,450评论 0 0