`

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

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics