博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Tomcat:基于HTTP协议的Connector配置
阅读量:7078 次
发布时间:2019-06-28

本文共 1304 字,大约阅读时间需要 4 分钟。

 

Tomcat Connector 是请求接收环节与请求处理环节的连接器,具体点说,就是将接收到的请求传递给Tomcat WEB容器进行处理。

Tomcat可以处理的不同协议的请求,例如HTTP协议、AJP协议。其中AJP是Tomcat与其他Web Server(例如Apache Server、IIS等)连接使用的协议。

对于HTTP协议,根据处理Socket中IO的方式的不同,又可以分为BIO、NIO、APR方式。

下面就针对Tomcat 6中的BIO、NIO方式作一个简单的说明:

BIO 方式:

Acceptor负责接收Socket,然后将socket传递给Worker队列中的一个worker。Worker的职责是调用HTTP11Processor,进行请求的解析,封装成Request Response对象然后由WEB容器来处理。

<Connector port="8080" protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443" />

1)acceptCount:是等待队列最大长度。说白了就是当所有的线程都被占用后,对列里还能放一个HTTP请求等待处理。通常这个数值要大于线程池中线程的最大数。Tomcat 6 源码中没有发现有这个字段的设置,需要确认。

2)maxThreads:线程池中的最大线程数。默认200。如果使用Executor,就是执行线程池的最大线程数,如果不使用Executor,就是指定worker的最大数,每一个worker持有一个Thread,所以也是设置最大处理线程数。

3)connectionTimeout:当Tomcat与访问端建立Socket连接后,连接器接收到请求前,最大等待时间。默认是60秒。

4)keepAliveTimeout:HTTP1.1默认使用keepalive方式的,就是在建立一个连接中,可以发多个HTTP请求。这个属性就是设置在连接被关闭之前,连接器会等待下一个HTTP请求多长时间(如果在指定时间内等不到下一个连接,就会关闭连接的)。

5)maxKeepAliveRequests:建立一个连接后,可以接收的最大请求数。默认值100.

NIO模式:

Acceptor采用NIO API接收SocketChannel,封装成NIOChannel,然后由Poller将其放到PollerEvent队列中。

Poller其实是封装了一个Selector,Pooler用于从PollerEvent选择可以处理的event进行处理。

在处理一个envent时,会将可处理的event发送给Worker队列中的一个worker,worker的处理过程与BIO中的一样。

1)acceptorThreadCount:接收Socket连接的线程数。默认值是1,这个值不需要太大,最大值与CPU核心数一样就行了,没有必要太大。

2)selecorTimeout:选择超时时间。

3)maxKeepAliveRequests:与BIO一样。

4)maxThreads最大线程数

转载地址:http://fipml.baihongyu.com/

你可能感兴趣的文章
React Native 环境搭建
查看>>
leetcode------Excel Sheet Column Title
查看>>
ceshi
查看>>
TrueCrypt 7.1a Hashes
查看>>
哪种编程语言好?
查看>>
Ubuntu 桌面死机后重启桌面方法
查看>>
Oracle 包(Package)
查看>>
Java中的时间日期处理
查看>>
Nginx 1.10.1 编译、配置文档(支持http_v2,TLSv1.2,openssl v1.0.2)
查看>>
2017年10月18日23:54:18
查看>>
难以置信,根本就没拖延症!
查看>>
linux文件系统实现浅析
查看>>
【转】Python3 configparse模块(配置)
查看>>
【转】实习小记-python 内置函数__eq__函数引发的探索
查看>>
C++日记 VS编译问题
查看>>
(转)PHP开发框架浅析
查看>>
最近iOS工作不好找,也不知道我还能坚持多久 。写些东西省的忘了!分享给大家!...
查看>>
Hui之Hui.js 官方文档
查看>>
#无参数get请求 r = requests.get(url)
查看>>
LeetCode(82): Remove Duplicates from Sorted List II
查看>>