Tomcat笔记

时间:2021-05-30 05:43:01

总体架构:
由三部分组成:Service、Connector、Container
多个Connector对应一个Container,构成一个Service
为Service提供一个生存环境

如何处理多用户同时请求
1、用户浏览器请求
2、Connector将TCP信息封装,创建Request、response
3、开启一个线程将TCP信息,Request、Response传给Container容器
4、Container中的是个容器处理,返回request rsponse给客户端
5、request response对象生命周期结束,关闭当前Socket

多级容器如何协调工作:
略略略略略略

运用了哪些设计模式:
  门面设计模式:在大的系统中,每个子系统之间要进行互相通信,但内部的数据不能完全暴露给其他子系统,这样就不存在子系统之分了
         于是门面设计模式解决这一问题,他把其他子系统关系的数据暴露出来,构成一个访问门面,供其他子系统访问。
           如:Request Response对象的封装
  观察者设计模式:事件监听机制,如:session状态改变的监听
  任务链设计模式:每个对象对其下家的引用将很多对象串联起来构成一条任务执行链,请求在这条链上传递
                 优点.在不影响用户请求的情况下对这条链增添其他功能,优点想AOP思想
          Container中四大容器的相关联:Engine--->Host--->Context--->Wrapper

内存优化
windows修改TOMCAT_HOME/bin/catalina.bat,在前面加入
set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m
-Xms java虚拟机初始化时的最小内存; 512
  -Xmx java虚拟机可使用的最大内存;1024
  -XX: PermSize 内存永久保留区域:64
  -XX:MaxPermSize 内存最大永久保留区域:128

线程优化:
<Connector port="80" protocol="HTTP/1.1" maxThreads="600" minSpareThreads="100" maxSpareThreads="500" acceptCount="700"
connectionTimeout="20000" redirectPort="8443" />
maxThreads="600" ///最大线程数
minSpareThreads="100"///初始化时创建的线程数
maxSpareThreads="500"///一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。
acceptCount="700"//指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理

禁用DNS查询
为了避免服务器获取难以的到的用户请求IP浪费时间,
可修改server.xml中Connector元素,修改属性enableLookups参数值: enableLookups="false"
如果为true,则可以调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名
若为false则不进行DNS查询,而是返回其ip地址'

设置session过期时间
conf\web.xml中通过参数指定:

<session-config>
<session-timeout>180</session-timeout>
</session-config>
单位为分钟

缓存优化
1>参数说明

  compression 打开压缩功能
  compressionMinSize 启用压缩的输出内容大小,这里面默认为2KB
  compressableMimeType 压缩类型
  connectionTimeout 定义建立客户连接超时的时间. 如果为 -1, 表示不限制建立客户连接的时间

  2>Tomcat中的配置示例

  <Connector port="9027"
  protocol="HTTP/1.1"
  maxHttpHeaderSize="8192"
  maxThreads="1000"
  minSpareThreads="100"
  maxSpareThreads="1000"
  minProcessors="100"
  maxProcessors="1000"
  enableLookups="false"
  compression="on"
  compressionMinSize="2048"
  compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
  connectionTimeout="20000"
  URIEncoding="utf-8"
  acceptCount="1000"
  redirectPort="8443"
  disableUploadTimeout="true"/>