欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Tomcat优化

程序员文章站 2022-07-13 10:30:41
...

一、Tomcat 服务器的目录结构

 /bin:脚本文件目录。

 /common/lib:存放所有web项目都可以访问的公共jar包(使用Common类加载器加载)。

 /conf:存放配置文件,最重要的是server.xml。

 /logs:存放日志文件。

 /server/webapps:来管理Tomcat-web服务用的。仅对TOMCAT可见,对所有的WEB APP都不可见(使用Catalina类加载器加载)。

 /shared/lib:仅对所有WEB APP可见,对TOMCAT不可见(使用Shared类加载器加载)。

 /temp:Tomcat运行时候存放临时文件用的。

 /webapps:web应用发布目录。

 /work:Tomcat把各种由jsp生成的servlet文件放在这个目录下。删除后,启动时会自动创建。

 

二、配置文件参数说明

server.xml:主要的配置文件。

 web.xml:缺省的web app配置,WEB-INF/web.xml会覆盖该配置。

 context.xml:在5.5之后推荐的配置文件,不要在server.xml里面配置context,应为server.xml配置文件是不可以动态加载的资源,在启动之后对

 

server.xml文件的修改就只能重启服务才可以使用。

 server.xml配置

server标签下的属性说明

port:指定一个端口,这个端口负责监听关闭tomcat的请求。

shutdown:指定向端口发送的命令字符串。默认是SHUTDOWN,为了防止攻击这个参数值最好改为自己设置的值

service标签下的属性说明

 name:指定service的名字。

 

Connector(表示客户端和service之间的连接)标签的属性说明

 port:指定服务器端要创建的端口号,并在这个端口监听来自客户端的请求。

 minProcessors:服务器启动时创建的处理请求的线程数。

 maxProcessors:最大可以创建的处理请求的线程数。

 enableLookups:如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询

 

,而是返回其ip地址。在实际部署时为了提高新能需要把这个值设置为false,减少DNS查询的性能消耗。

 redirectPort:指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号。

 acceptCount:指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。

 connectionTimeout:指定超时的时间数(以毫秒为单位)。

 

protocol     三种模式 分别是:

BIO 默认的方式一个请求一个线程

NIO  用JAVA的异步IO实现,配置的值是:org.apache.coyote.http11.Http11NioProtocol,可以通过少量的线程处理大量的请求。

APR:通过操作系统层面解决IO阻塞问题,Linux如果安装了apr和native,Tomcat直接启动就支持apr,配置值是:

 

org.apache.coyote.http11.Http11AprProtocol  ,线程数量受到操作系统的限制,Window下面是2000,Linux下面是1000.

 

compression="on" 打开压缩功能

compressionMinSize="2048" 启用压缩的输出内容大小,这里面默认为2KB

noCompressionUserAgents="gozilla, traviata" 对于以下的浏览器,不启用压缩 

compressableMimeType="text/html,text/xml" 压缩类型

 

Engine(表示指定service中的请求处理机,接收和处理来自Connector的请求)标签

 defaultHost:指定缺省的处理请求的主机名,它至少与其中的一个host元素的name属性值是一样的。

 

 Context(表示一个web应用程序,通常为WAR文件,关于WAR的具体信息见servlet规范)标签

 docBase:该web应用的文档基准目录(Document Base,也称为Context Root),或者是WAR文件的路径。可以使用绝对路径,也可以使用相对于

 

context所属的Host的appBase路径。

 path:表示此web应用程序的url的前缀,这样请求的url为http://localhost:8080/path/****。

 reloadable:这个属性非常重要,如果为true,则tomcat会自动检测应用程序的/WEB-INF/lib和/WEB-INF/classes目录的变化,自动装载新的应用程

 

序,我们可以在不重起tomcat的情况下更新应用程序。

 useNaming:如果希望Catalina为该web应用使能一个JNDI InitialContext对象,设为true。该InitialialContext符合J2EE平台的约定,缺省值为

 

true。

 workDir:Context提供的临时目录的路径,用于servlet的临时读/写。利用javax.servlet.context.tempdir属性,servlet可以访问该目录。如果没

 

有指定,使用$CATALINA_HOME/work下一个合适的目录。

 swallowOutput:如果该值为true,System.out和System.err的输出被重定向到web应用的logger。如果没有指定,缺省值为false

 debug:与这个Engine关联的Logger记录的调试信息的详细程度。数字越大,输出越详细。如果没有指定,缺省为0。

 

 host(表示一个虚拟主机)标签

 name:指定主机名。

 appBase:应用程序基本目录,即存放应用程序的目录。

 unpackWARs:如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序。

 

 Logger(表示日志,调试和错误信息)标签

 className:指定logger使用的类名,此类必须实现org.apache.catalina.Logger接口。

 prefix:指定log文件的前缀。

 suffix:指定log文件的后缀。

 timestamp:如果为true,则log文件名中要加入时间,如下例:localhost_log.2001-10-04.txt。

 

 Realm(表示存放用户名,密码及role的数据库)标签

 className:指定Realm使用的类名,此类必须实现org.apache.catalina.Realm接口。

 

 Valve(功能与Logger差不多,其prefix和suffix属性解释和Logger  中的一样)标签

 className:指定Valve使用的类名,如用org.apache.catalina.valves.AccessLogValve类可以记录应用程序的访问信息。

 directory:指定log文件存放的位置。

 pattern:有两个值,common方式记录远程主机名或ip地址,用户名,日期,第一行请求的字符串,HTTP响应代码,发送的字节数。combined方式比

 

common方式记录的值更多

 

三、参数优化

a)JVM参数调优:-Xms<size> 表示JVM初始化堆的大小,-Xmx<size>表示JVM堆的最大值。这两个值的大小一般根据需要进行设置。当应用程序

 

需要的内存超出堆的最大值时虚拟机就会提示内存溢出,并且导致应用服务崩溃。因此一般建议堆的最大值设置为可用内存的最大值的80%。在

 

catalina.bat 中,设置JAVA_OPTS='-Xms512m -Xmx512m',表示初始化内存为512MB,可以使用的最大内存为512MB,具体的值根据服务器的硬件配置

 

来设置,堆的最大和最小值设置为相等,减少空间的申请所耗费的时间。

b)禁用DNS查询

在Connector  标签下设置属性   enableLookups="false"

c)调整线程数

调整Connector 标签下的线程数量

maxProcessors的值也是有上限的,应防止流量不可控制(或者恶意的服务攻击),从而导致超出了虚拟机使用内存的大小。如果要加大并发连接数,

 

应同时加大这两个参数。web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。

d)启用gzip(HTTP压缩) 压缩功能

Connector 启用APR模式,提高系统传输的效率。