Tomcat优化
一、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模式,提高系统传输的效率。