Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,目前最新版本是6.x,相对5.x性能提升很多,主要优化了内存使用,增强IO能力,重新构造集群功能。
近期对Tomcat6.x作深入学习,参考上述声明的Tomcat全攻略,由于笔者是2001年针对Tomcat4.x所写,故参考之并针对Tomcat6.x做了总结,形成此篇学习笔记,希望对学习的人有所帮助,本文涵盖了:Tomcat目录、Server.xml元素讲解,数据库连接池配置、线程池配置、虚拟目录配置。关于如何下载、安装、运行Tomcat略,请google,相信有详细的文章讲述。
tomcat的目录结构如下:
目录名 |
简介 |
bin |
存放启动和关闭tomcat脚本 |
conf |
包含不同的配置文件,server.xml(Tomcat的主要配置文件)和web.xml |
work |
存放jsp编译后产生的class文件 |
webapp |
存放应用程序示例,以后你要部署的应用程序也要放到此目录 |
logs |
存放日志文件 |
lib |
这三个目录主要存放tomcat所需的jar文件 |
server.xml配置简介
元素名 |
属性 |
解释 |
server |
port |
指定一个端口,这个端口负责监听关闭tomcat的请求 |
shutdown |
指定向端口发送的命令字符串 |
|
GlobalNamingResources |
服务器的全局JNDI资源,可以有子标签<Resource></Resource> |
|
Executor(线程池,一个或多个Connector可以共享此线程池) |
name |
线程池名称,名称必须唯一 |
namePrefix |
线程的名字前缀,用来标记线程名字的,这样每个线程就用这个前缀加上线程编号了,比如 catalina-exec-1、catalina-exec-2 |
|
maxThreads |
允许的最大线程池里的线程数量,默认是200,大的并发应该设置的高一些,反正只是限制而已,不占用资源 |
|
minSpareThreads |
最小的保持活跃的线程数量,默认是25.这个要根据负载情况自行调整了。太小了就影响反应速度,太大了白白占用资源 |
|
maxIdleTime |
最小的保持活跃的线程数量,默认是25.这个要根据负载情况自行调整了。太小了就影响反应速度,太大了白白占用资源 |
|
threadPriority |
线程的等级。默认是Thread.NORM_PRIORITY |
|
service |
name |
指定service的名字 |
Connector (表示客户端和service之间的连接) |
port |
指定服务器端要创建的端口号,并在这个断口监听来自客户端的请求 |
minProcessors |
服务器启动时创建的处理请求的线程数 |
|
maxProcessors |
最大可以创建的处理请求的线程数 |
|
enableLookups |
如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址 |
|
redirectPort |
指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号 |
|
acceptCount |
指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理 |
|
connectionTimeout |
指定超时的时间数(以毫秒为单位) |
|
Engine (表示指定service中的请求处理机,接收和处理来自Connector的请求) |
name |
|
defaultHost |
指定缺省的处理请求的主机名,它至少与其中的一个host元素的name属性值是一样的 |
|
jvmRoute |
||
host (表示一个虚拟主机、并且可以包含Context子节点配置虚拟目录) |
name |
指定主机名 |
appBase |
应用程序基本目录,即存放应用程序的目录 |
|
unpackWARs |
如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序 |
|
autoDeploy |
自动部署 |
|
xmlValidation |
是否验证xml |
|
xmlNamespaceAware |
||
Realm (表示存放用户名,密码及role的数据库) |
className |
指定Realm使用的类名,此类必须实现org.apache.catalina.Realm接口 |
Context(host子节点配置虚拟目录) |
path |
虚拟目录名称 |
docBase |
物理路径 |
|
Debug |
Debug模式 |
|
Reload |
True 重新加载,修改后自动加载 |
上面我们讲述了server .xml个元素的含义,下面我们给出详细示例
Tomcat数据库连接池配置如下:
server.xml配置Resource
- <Resource name="jdbc/ExampleDB" auth="Container" type="javax.sql.DataSource"
- maxActive="100" maxIdle="30" maxWait="10000"
- username="APP" password="APP" driverClassName="org.apache.derby.jdbc.ClientDriver"
- url="jdbc:derby://localhost:1527/springside-example;create=true"/>
context.xml文件增加:
- <WatchedResource>WEB-INF/web.xml</WatchedResource>
- <ResourceLink name="jdbc/ExampleDB" global="jdbc/ExampleDB" type="javax.sql.DataSource"/>
Tomcat共享线程池配置:
取消Executor注释,修改连接数至自己合适的数值既可。
- <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
- maxThreads="200" minSpareThreads="100" maxIdleTime="60000"/>
executor="tomcatThreadPool" 标明此连接使用上面配置的名称为tomcatThreadPool的连接池,无属性共享连接不会生效 protocol表示使用的是 http协议 端口号为8080
- <Connector port="8080" protocol="HTTP/1.1" redirectPort="8443"
- connectionTimeout="20000"
- executor="tomcatThreadPool"
- acceptCount="100"
- useBodyEncodingForURI="true"
- enableLookups="false"
- />
虚拟目录配置:
在<host></host>之间增加如下
<!-- 配置虚拟目录,例如:http://localhost:8080 -->
- <Context path="/" docBase="D:workspacecodeHBJHweb"></Context>
附件中是取自springside3中,Tomcat production config配置示例,即生产环境下Tomcat配置