如何利用Java NIO实现高性能高并发的http服务器

在学习Java NIO的过程当中,我一直理解不了Java NIO是怎么用来实现高并发的服务器的,网上给出的例子里,基本上没有多少说到这一点的,Tomcat,Jetty这些的源码又太庞大了,致使我无从下手。服务器

后来搜了下才发现,JDK自带了一个httpserver的实现,看了下代码,很是简洁,很是规范,一会儿就让我搞懂了Java NIO是怎么实现高并发的了。并发

NIO是同步非阻塞模型,同步是指用NIO读取数据,须要你的线程一直在运行着,直到数据读写完毕。非阻塞是指监听通道的时候是非阻塞的,好比向通道询问有没有数据可读的时候,能够立刻就返回有或者没有。若是有数据,你的线程就能够去处理读数据这部分的逻辑;若是没有数据,你的线程能够去忙其余的事情,这样子单个线程的处理能力就会高不少,不用老是等着数据。高并发

在jdk的httpserver里,处理请求的过程大体以下图:学习

图片描述

相关文章
相关标签/搜索