Acceptor负责用来管理连接到tomcatserver的数量,来看看Acceptor在tomcatserver中的应用,是怎样实现连接管理的,socket连接建立成功之后,是怎样实现内容的读写的(读写是交由Poller机制去完毕)。


先准备一点java nio中实现socket连接所需的基础知识:SocketChannel和ServerSocketChannel

SocketChannel和ServerSocketChannel的概念与基础的堵塞式的java 网络编程中的socket和serversocket类似。
在后者的模型中,server端生成一个serversocket对象。bind绑定port号,然后accept堵塞等待client连接到server。每当连接建立成功,则返回一个Socket对象。用来表示连接建立成功。

在java nio中。ServerSocketChannel和SocketChannel模型事实上是与ServerSocket和Socket模型相应的。server端open打开一个ServerSocketChannel。这个操作同一时候会成功一个ServerSocket对象,但生成的ServerSocket对象是没有进行port绑定的。所以在进行网络监听之前,还须要对ServerSocketChannel的ServerSocket对象进行bind绑定操作。

然后ServerSocketChannel開始进行accept网络监听,请求建立成功之后返回一个SocketChannel对象。这个SocketChannel对象有一个与之相应的Socket对象。

ServerSocketChannel是线程安全的 ---- at least the Oracle documentation says so.


[ServerSocketChannel的初始化]
一个port号仅仅能相应一个SocketChannel,因此也仅仅能相应一个ServerSocketChannel。因此这个ServerSocketChannel是在多个Acceptor线程之间共享的。它是NioEndpoint的一个属性,在NioEndpoint中进行初始化。
在Endpoint模型中,有一个bind方法,用来绑定port。

ServerSocketChannel对象在这种方法中完毕初始化。截取的部分代码例如以下所看到的,这里省略了与此主题无关的代码。

     public void bind() throws Exception
{

        serverSock = ServerSocketChannel.open();
        socketProperties.setProperties(serverSock.socket());
        InetSocketAddress addr = (getAddress()!= null?

new InetSocketAddress(getAddress(),getPort()):new InetSocketAddress(getPort()));

        serverSock.socket().bind(addr,getBacklog());
        serverSock.configureBlocking( true); //mimic
APR behavior
        serverSock.socket().setSoTimeout(getSocketProperties().getSoTimeout());
     }
[Acceptor线程组的初始化]

Acceptor线程组中线程的个数是可配置的。这一点和Poller线程组中的线程个数一样,能够由配置文件来进行配置。仅仅是大部分情况下不须要罢了。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveWFubGlud2FuZw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

Acceptor线程组的初始化在NioEndpoint的startInternal中进行,属于Endpoint初始化的一部分。


[连接数控制]

当一个新的连接请求到达时。怎样推断是否接收建立连接请求?

Endpoint有个maxConnection属性,用来规定server所能接受的最大连接数。默认是10000。


在NioEndpoint初始化的时候,会使用maxConnection来初始化一个LimitLatch,使用这个LimitLatc来进行并发请求连接的管理。

对LimitLatch的理解能够參考java current包里面的CountDownLatch。


Acceptor线程的执行主体部分,使用while(true)来进行循环。

主要是进行serverSocket.accept的监听。对ServerSocketChannel使用blocking模式。所以当没有连接请求来时,线程会堵塞在accept方法上。


当有新的请求到达时,使用countUpOrAwaitConnection来管理连接数。假设连接数还没有达到最大值。就将LimitLatch的值加1,LimitLatch的值就表示了当前与服务端建立连接的个数。

假设已经达到了最大值,则让线程等待。


     与连接控制管理相关的代码例如以下所看到的。

                    //if we have reached max connections, wait
                    countUpOrAwaitConnection();

                    SocketChannel socket = null ;
                    try {
                        // Accept the next incoming
connection from the server
                        // socket
                        socket = serverSock.accept();
                    } catch (IOException
ioe) {
                        //we didn't get a socket
                        countDownConnection();
                        // Introduce delay if necessary
                        errorDelay = handleExceptionWithDelay(errorDelay);
                        // re-throw
                        throw ioe;
                    }
                    // Successful accept, reset the
error delay
                    errorDelay = 0;

                    // setSocketOptions() will add
channel to the poller
                    // if successful
                    if (running
&& !paused) {
                        if (!setSocketOptions(socket))
{
                            countDownConnection();
                            closeSocket(socket);
                        }
                    } else {
                        countDownConnection();
                        closeSocket(socket);
                    }
当出现异常情况。就使用countDownConnection来将连接数减一。


[连接的传递]

管理连接的建立差点儿相同就是Acceptor的主要工作了,连接建立好之后。最后的工作就是交给Poller去实现数据的读写。在setSocketOptions中实现了SocketChannel对Poller的注冊。

tomcatserver解析(六)-- Acceptor的更多相关文章

  1. Celery 源码解析六:Events 的实现

    在 Celery 中,除了远程控制之外,还有一个元素可以让我们对分布式中的任务的状态有所掌控,而且从实际意义上来说,这个元素对 Celery 更为重要,这就是在本文中将要说到的 Event. 在 Ce ...

  2. Spring Security 解析(六) —— 基于JWT的单点登陆(SSO)开发及原理解析

    Spring Security 解析(六) -- 基于JWT的单点登陆(SSO)开发及原理解析   在学习Spring Cloud 时,遇到了授权服务oauth 相关内容时,总是一知半解,因此决定先把 ...

  3. Java 面试知识点解析(六)——数据库篇

    前言: 在遨游了一番 Java Web 的世界之后,发现了自己的一些缺失,所以就着一篇深度好文:知名互联网公司校招 Java 开发岗面试知识点解析 ,来好好的对 Java 知识点进行复习和学习一番,大 ...

  4. ReactiveCocoa源码解析(六) SignalProtocol的take(first)与collect()延展实现

    上篇博客我们聊了observe().map().filter()延展函数的具体实现方式以及使用方式.我们在之前的博客中已经聊过,Signal的主要功能是位于SignalProtocol的协议延展中的, ...

  5. ReactiveSwift源码解析(六) SignalProtocol的take(first)与collect()延展实现

    上篇博客我们聊了observe().map().filter()延展函数的具体实现方式以及使用方式.我们在之前的博客中已经聊过,Signal的主要功能是位于SignalProtocol的协议延展中的, ...

  6. tomcatserver解析(五)-- Poller

    在前面的分析中介绍过,Acceptor的作用是控制与tomcat建立连接的数量,但Acceptor仅仅负责建立连接.socket内容的读写是通过Poller来实现的.   Poller使用java n ...

  7. volley源代码解析(六)--HurlStack与HttpClientStack之争

    Volley中网络载入有两种方式,各自是HurlStack与HttpClientStack.我们来看Volley.java中的一段代码 if (stack == null) {//假设没有限定stac ...

  8. ReactiveCocoa源码拆分解析(六)

    (整个关于ReactiveCocoa的代码工程可以在https://github.com/qianhongqiang/QHQReactive下载) RAC为了实现优雅的信号绑定,可谓使尽浑身解数,不仅 ...

  9. AFNetworking (3.1.0) 源码解析 <六>

    这次继续介绍文件夹Serialization下的类AFURLResponseSerialization.这次介绍就不拆分了,整体来看一下.h和.m文件. 协议AFURLResponseSerializ ...

随机推荐

  1. SQL Server Insert操作中的锁

    原文:SQL Server Insert操作中的锁 这篇博文简单介绍一下在SQL Server中一条Insert语句中用到的锁. 准备数据 首先我们建立一张表Table_1,它有两列Id(bigint ...

  2. POJ 2536 Gopher II(二分图的最大匹配)

    题目链接:http://poj.org/problem?id=2536 题意:已知有n仅仅老鼠的坐标,m个洞的坐标,老鼠的移动速度为V,S秒以后有一仅仅老鹰要吃老鼠,问有多少个老鼠被吃. 非常明晰,二 ...

  3. CodeForces 343D 线段树维护dfs序

    给定一棵树,初始时树为空 操作1,往某个结点注水,那么该结点的子树都注满了水 操作2,将某个结点的水放空,那么该结点的父亲的水也就放空了 操作3,询问某个点是否有水 我们将树进行dfs, 生成in[u ...

  4. Xamarin.Android中使用android:onClick="xxx"属性

    原文:Xamarin.Android中使用android:onClick="xxx"属性 在原生Android开发中,为一个View增加点击事件,有三种方式: 1.使用匿名对象 ( ...

  5. Galaxy (hdu 5073 数学)

    Galaxy Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) Total S ...

  6. 重新想象 Windows 8 Store Apps (5) - 控件之集合控件: ComboBox, ListBox, FlipView, ItemsControl, ItemsPresenter

    原文:重新想象 Windows 8 Store Apps (5) - 控件之集合控件: ComboBox, ListBox, FlipView, ItemsControl, ItemsPresente ...

  7. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(四)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  8. 【原创】leetCodeOj --- Merge k Sorted Lists 解题报告

    题目地址: https://oj.leetcode.com/problems/merge-k-sorted-lists/ 题目内容: /** * Definition for singly-linke ...

  9. WebService什么?

    一.前言 我们或多或少都听过WebService(Web服务),有一段时间非常多计算机期刊.书籍和站点都大肆的提及和宣传WebService技术.当中不乏非常多吹嘘和做广告的成分.可是不得不承认的是W ...

  10. CMake入门(二)

    CMake入门(二) 最后更新日期:2014-04-25 by kagula 阅读前提:<CMake入门(一)>.Linux的基本操作 环境: Windows 8.1 64bit英文版.V ...