[Tomcat6.0源码]请求的处理一Socket
来源:互联网 发布:云计算介绍ppt 编辑:程序博客网 时间:2024/04/29 10:43
《组件的启动》中JIoEndpoint的start会启动Acceptor.run来监听请求(Acceptor是JIoEndpoint的内部类):
Socket socket = serverSocketFactory.acceptSocket(serverSocket); serverSocketFactory.initSocket(socket); // Hand this socket off to an appropriate processor if (!processSocket(socket)) { // Close socket right away try { socket.close(); } catch (IOException e) { // Ignore } }
这个serverSocketFactory,serverSocket都来自JIoendpoint.init()中:
serverSocketFactory = ServerSocketFactory.getDefault();
serverSocket = serverSocketFactory.createSocket(port, backlog, address);
getDefault返回的是DefaultServerSocketFactory实例,DefaultServerSocketFactory.acceptSocket():
public Socket acceptSocket(ServerSocket socket) throws IOException { return socket.accept(); }
这里只是对ServerSocket的accpet()方法做一个简单的封装,Acceptor线程处于阻塞状态,当serverSocket监听到请求时,才会执行以后的代码。
serverSocketFactory.initSocket(socket);这个initSocket真的是没干什么,连一行代码都没有。
访问http://localhost:8080 接收到请求后JIoEndpoint.processSocket(socket)处理socket:
protected boolean processSocket(Socket socket) { try { if (executor == null) { getWorkerThread().assign(socket); } else { executor.execute(new SocketProcessor(socket)); } } catch (Throwable t) { // This means we got an OOM or similar creating a thread, or that // the pool and its queue are full log.error(sm.getString("endpoint.process.fail"), t); return false; } return true; }
线程池没配置executor为null,所以会执行getWorkerThread().assign(socket);
JIoEndpoint.getWorkerThread():
protected Worker getWorkerThread() { // Allocate a new worker thread synchronized (workers) { Worker workerThread; while ((workerThread = createWorkerThread()) == null) { try { workers.wait(); } catch (InterruptedException e) { // Ignore } } return workerThread; } }
JIoEndpoint.createWorkerThread():
protected Worker createWorkerThread() { synchronized (workers) { if (workers.size() > 0) { curThreadsBusy++; return workers.pop(); } if ((maxThreads > 0) && (curThreads < maxThreads)) { curThreadsBusy++; if (curThreadsBusy == maxThreads) { log.info(sm.getString("endpoint.info.maxThreads", Integer.toString(maxThreads), address, Integer.toString(port))); } return (newWorkerThread()); } else { if (maxThreads < 0) { curThreadsBusy++; return (newWorkerThread()); } else { return (null); } } } }
如果没有多余的空闲worker,且worker数量没达到最大,就new一个,JIoEndpoint.newWorkerThread():
protected Worker newWorkerThread() { Worker workerThread = new Worker(); workerThread.start(); return (workerThread); }
Worker.run():
public void run() { // Process requests until we receive a shutdown signal while (running) { // Wait for the next socket to be assigned Socket socket = await(); if (socket == null) continue; // Process the request from this socket if (!setSocketOptions(socket) || !handler.process(socket)) { // Close socket try { socket.close(); } catch (IOException e) { } } // Finish up this request socket = null; recycleWorkerThread(this); } }
Worker.await():
private synchronized Socket await() { // Wait for the Connector to provide a new Socket while (!available) { try { wait(); } catch (InterruptedException e) { } } // Notify the Connector that we have received this Socket Socket socket = this.socket; available = false; notifyAll(); return (socket); }
available初始值为false,至此,getWorkerThread()方法已经执行完,线程处于等待状态,连while循环的停了。回到getWorkerThread().assign(socket):
synchronized void assign(Socket socket) { // Wait for the Processor to get the previous Socket while (available) { try { wait(); } catch (InterruptedException e) { } } // Store the newly available Socket and notify our thread this.socket = socket; available = true; notifyAll(); }
available改成true;notifyAll()唤醒等待的线程,Worker.await()返回socket。Worker.run()接收到这个返回的socket,就会往下执行。
捋一捋:
1.JIoEndpoint创建一个Acceptor线程来监听请求。
2.Acceptor监听到请求后,就到Worker池中取一个对象来(Worker用栈来维护)。Worker是多线程的,创建的时候处理socket的run方法就被等待。
3.给Worker对象分配socket,唤醒run()方法做进一步处理。
- [Tomcat6.0源码]请求的处理一Socket
- [Tomcat6.0源码]请求的处理二Request
- [Tomcat6.0源码]请求的处理四Pipeline、Valve、FilterChain
- [Tomcat6.0源码]请求的处理三Mapper、JMX
- tomcat6源码分析三(请求处理过程)
- tomcat6源码分析三(请求处理过程)
- Tomcat6.0源码学习--接受并传递请求
- Tomcat6.0源码学习--接受并传递请求
- Struts2源码分析--请求处理(一)
- django源码解析一(请求处理流程)
- Tomcat6 NIO源码剖析一
- Tomcat6 NIO源码剖析一
- [Tomcat6.0源码]强大的Digester
- [Tomcat6.0源码]组件的实例化
- [Tomcat6.0源码]项目的部署
- [Tomcat6.0源码]组件的初始化
- [Tomcat6.0源码]组件的启动
- [Tomcat6.0源码]设计模式的使用
- Java类 成员 访问权限 默认
- 清空textbox
- Windows 消息机制
- Metasploit Framework 简介与使用
- WebSocket通信协议介绍
- [Tomcat6.0源码]请求的处理一Socket
- 规定时间内响应一次按钮单击事件
- 仿写 微信 界面
- 杭电OJ——1018 Big number!
- 如何在手机内部搭建RTSP服务器
- 浅谈HTTP中Get与Post的区别
- 如何使用Access创建一个简单MIS管理系统_Access
- sscanf备注
- Minimum Inversion Number----HDU_1394----线段树之单点更新