总体架构:
由三部分组成: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"/>