tomcat5.5.x 配置记录
1.下载
http://www.eu.apache.org/dist/jakarta/tomcat-5/
http://www.apache.org/dist/jakarta/tomcat-5/v5.5.x/bin/jakarta-tomcat-5.5.x-admin.zip
http://www.apache.org/dist/jakarta/tomcat-5/v5.5.x/bin/jakarta-tomcat-5.5.x-compat.zip
http://www.apache.org/dist/jakarta/tomcat-5/v5.5.x/bin/jakarta-tomcat-5.5.x.zip
http://www.apache.org/dist/jakarta/tomcat-5/v5.5.x/bin/jakarta-tomcat-5.5.x-deployer.zip
把jakarta-tomcat-5.5.x.zip
和jakarta-tomcat-5.5.x-compat.zip
和jakarta-tomcat-5.5.x-admin.zip
(Tomcat 默认是没有内置admin模块了
Tomcat's administration web application is no longer installed by default. Download and install the "admin" package to use it. )
都解压到同一个目录下面。比如:D:\jakarta-tomcat-5.5.x\
(如果使用jdk1.4,才需要compat.zip用jdk1.5就可以免了这个。)
2.修改jakarta-tomcat-5.5.x\conf\tomcat-users.xml
添加管理员账号lizongbo,密码为lizongbopass.
新xml如下:
<?xml version='1.0' encoding='utf-8'?>
<tomcat-users>
<role rolename="tomcat"/>
<role rolename="role1"/>
<role rolename="manager"/>
<role rolename="admin"/>
<user username="tomcat" password="tomcat" roles="tomcat"/>
<user username="role1" password="tomcat" roles="role1"/>
<user username="both" password="tomcat" roles="tomcat,role1"/>
<user username="lizongbo" password="lizongbopass" roles="admin,manager"/>
</tomcat-users>
3.修改jakarta-tomcat-5.5.x\conf\server.xml来解决编码问题
(给Connector 添加URIEncoding参数,参考http://blog.csdn.net/darkxie/archive/2004/10/25/TOMCATAPP.aspx)
(可以设置成GB18030)
<Connector port="8080"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="200"
connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="GBK"
compression="on" compressionMinSize="2048"
noCompressionUserAgents="gozilla, traviata"
compressableMimeType="text/html,text/xml"/>
<Connector port="8009"
enableLookups="false" redirectPort="8443" protocol="AJP/1.3" URIEncoding="GBK"/>
4.启用支持gzip压缩
(http://www.linuxaid.com.cn/forum/showdoc.jsp?l=1&i=81169)
添加下列属性
compression="on"
compressionMinSize="2048"
noCompressionUserAgents="gozilla, traviata"
compressableMimeType="text/html,text/xml"
5.设置虚拟主机
在jakarta-tomcat-5.5.x\下建立文件夹vhost\www.mydomain.com。
然后修改jakarta-tomcat-5.5.x\conf\server.xml
<Engine defaultHost="localhost" name="Catalina">
<Host appBase="vhost/www.mydomain.com" name="www.mydomain.com">
</Host>
<Host appBase="webapps" name="localhost">
</Host>
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"/>
</Engine>
6.添加数据库驱动,更新mail.jar和actiovation.jar
复制mysql-connector-java-3.0.16-ga-bin.jar,pg74.215.jdbc3.jar到 jakarta-tomcat-5.5.x\common\lib\
还有javamail 1.3.2的mail.jar,jaf-1_0_2的 activation.jar
msSQl 2000 JDBC sp3,msbase.jar,msutil,jar,mssqlserver.jar
7.配置SSL
参考 http://jakarta.apache.org/tomcat/tomcat-5.5-doc/ssl-howto.html
D:\j2sdk1.4.2_06\bin>%JAVA_HOME%\bin\keytool -genkey -alias tomcat -keyalg RSA
输入keystore密码: lizongbossl
您的名字与姓氏是什么?
[tomcat5.5.x]: tomcat5.5.x
您的组织单位名称是什么?
[jakarta]: jakarta
您的组织名称是什么?
[apache]: apache
您所在的城市或区域名称是什么?
[hzcity]: hzcity
您所在的州或省份名称是什么?
[gdp]: gdp
该单位的两字母国家代码是什么
[CN]: CN
CN=tomcat5.5.x, OU=jakarta, O=apache, L=hzcity, ST=gdp, C=CN 正确吗?
[否]: y
输入<tomcat>的主密码
(如果和 keystore 密码相同,按回车):
(必须密码一致,因此直接回车)
然后再把userhome(例如:C:\Documents and Settings\lizongbo\)下的.keystore复制到
tomcat的conf\目录下。
(例如:D:\jakarta-tomcat-5.5.x\conf\.keystore )
配置jakarta-tomcat-5.5.x\conf\server.xml
加上
<Connector port="8443"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" disableUploadTimeout="true"
acceptCount="100" scheme="https" secure="true"
clientAuth="false" sslProtocol="TLS"
keystoreFile="conf/.keystore"
keystorePass="lizongbossl"> <!--与先前设置的密码一致-->
</Connector>
8.禁止文件目录列表
修改jakarta-tomcat-5.5.x\conf\web.xml,把listing设置为false
<servlet>
<servlet-name>default</servlet-name>
<servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>0</param-value>
</init-param>
<init-param>
<param-name>listings</param-name>
<param-value>true</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
9.指定了自己的javaEncoding
(参考 http://gceclub.sun.com.cn/staticcontent/html/sunone/app7/app7-dg-webapp/ch6/ch6-4.html )
<servlet>
<servlet-name>jsp</servlet-name>
<servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>
<init-param>
<param-name>fork</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>javaEncoding</param-name>
<param-value>GB18030</param-value>
</init-param>
<init-param>
<param-name>xpoweredBy</param-name>
<param-value>true</param-value>
</init-param>
<load-on-startup>3</load-on-startup>
</servlet>
10.添加rar,iso等的mime-type映射
避免在浏览器里直接打开。
<mime-mapping>
<extension>mht</extension>
<mime-type>text/x-mht</mime-type>
</mime-mapping>
<mime-mapping>
<extension>rar</extension>
<mime-type>application/octet-stream</mime-type>
</mime-mapping>
<mime-mapping>
<extension>iso</extension>
<mime-type>application/octet-stream</mime-type>
</mime-mapping>
<mime-mapping>
<extension>ape</extension>
<mime-type>application/octet-stream</mime-type>
</mime-mapping>
<mime-mapping>
<extension>rmvb</extension>
<mime-type>application/octet-stream</mime-type>
</mime-mapping>
<mime-mapping>
<extension>ico</extension>
<mime-type>image/x-icon</mime-type>
</mime-mapping>
10.1对html静态页面设置编码
<!-- 修改下面两行以支持静态超文本的自动编码
-->
<mime-mapping>
<extension>htm</extension>
<mime-type>text/html;charset=gb2312</mime-type>
</mime-mapping>
<mime-mapping>
<extension>html</extension>
<mime-type>text/html;charset=gb2312</mime-type>
</mime-mapping>
</web-app>
11.添加welcome-file-list,并调整顺序
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
12.如果你的webapp需要只能够进行https方式访问,那么在webapp的web.xml里加上:
<security-constraint>
<web-resource-collection>
<web-resource-name>must https</web-resource-name>
<url-pattern>/*</url-pattern>
</web-resource-collection>
<user-data-constraint>
<transport-guarantee>CONFIDENTIAL</transport-guarantee>
</user-data-constraint>
</security-constraint>
参考:http://jakarta.apache.org/tomcat/faq/security.html#https
http://marc.theaimsgroup.com/?l=tomcat-user&m=104951559722619&w=2
13.修改远程关闭服务器的命令
server.xml默认有下面一行:
<Server port="8005" shutdown="SHUTDOWN">
这样允许任何人只要telnet到服务器的8005端口,输入"SHUTDOWN",然后回车,服务器立即就被关掉了。
从安全的角度上考虑,我们需要把这个shutdown指令改成一个别人不容易猜测的字符串。
例如修改如下:
<Server port="8006" shutdown="lizongbo">,这样就只有在telnet到8005,并且输入"lizongbo"才能够关闭Tomcat.
注意:这个修改不影响shutdown.bat的执行。运行shutdown.bat一样可以关闭服务器。
参考:http://jakarta.apache.org/tomcat/faq/security.html#8005
以下皆可以参考:http://www.cnjsp.org/document/user/tuman/valve.html
14.配置http访问日志
Tomcat自带的能够记录的http访问日志已经很详细了,取消下面这段的注释:
<Valve className="org.apache.catalina.valves.AccessLogValve"
directory="logs" prefix="localhost_access_log." suffix=".txt"
pattern="common" resolveHosts="false"/>
然后修改为:
<Valve className="org.apache.catalina.valves.FastCommonAccessLogValve"
directory="logs" prefix="localhost_access_log." suffix=".txt"
pattern="combined" resolveHosts="false" fileDateFormat="yyyy-MM-dd.HH"/>
pattern="combined" 记录的日志内容更详细,fileDateFormat="yyyy-MM-dd.HH",会让日志文件按小时进行滚卷,
比默认的按天滚卷要好些,尤其是访问量大的网站,可以考虑写成fileDateFormat="yyyy-MM-dd.HH.mm",就会是每分钟一个日志文件了。
而且可以分别按Engine, Host, or Context,来记录自己的日志
详情参考:
http://jakarta.apache.org/tomcat/tomcat-5.5-doc/config/valve.html
http://jakarta.apache.org/tomcat/tomcat-5.0-doc/config/logger.html
http://jakarta.apache.org/tomcat/tomcat-5.0-doc/config/host.html#Access%20Logs
而且还可以配合awstats来进行日志统计分析: http://www.chedong.com/tech/awstats.html http://blog.csdn.net/lizongbo/archive/2005/02/18/291929.aspx
15.限制ip,限制主机访问等
如果想禁止指定的ip或者主机名来拒绝某些机器访问,或者指定某些机器来访问。
也支持分别按Engine, Host, or Context,进行以下配置:
<Context path="/examples" ...> ...
<Valve className="org.apache.catalina.valves.RemoteHostValve"
allow="*.mycompany.com,www.yourcompany.com"/>
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
deny="192.168.1.*"/>
</Context>
参考:
http://jakarta.apache.org/tomcat/tomcat-5.0-doc/config/context.html
16.发布webapp到网站根目录
1。直接复制到ROOT目录下。
2.因为无法创建无名字的xml文件,并且在xml文件里指定path也是无效的(tomcat靠文件名字来判断的),
因此必须在server.xml里写下面一段:
<Context docBase="${catalina.home}/vhost/www.lizongbo.com" path="/"
privileged="true" antiResourceLocking="false" antiJARLocking="false">
<Manager className="org.apache.catalina.session.StandardManager" algorithm="SHA-512" sessionIdLength="40">
<Valve className="org.apache.catalina.valves.FastCommonAccessLogValve"
directory="logs" prefix="localhost_mytest_access_log." suffix=".txt"
pattern="combined" resolveHosts="true" fileDateFormat="yyyy-MM-dd.HH"/>
</Context>
而且必须把ROOT目录删除掉,否则Tomcat还是优先部署ROOT目录为"/"。
17.在重新启动Tomcat的webapp的时候,禁止把session写入文件
修改conf/web.xml
取消注释:
<!---->
<Manager pathname="" />
18.增强SessiionID的生成算法和长度
<Manager className="org.apache.catalina.session.StandardManager" algorithm="SHA-512" sessionIdLength="40">
</Manager>
(Tomcat默认算法是MD5,默认长度是16位。)
分享到:
相关推荐
`jdk1.5和tomcat5.5免安装的环境配置.txt`文件很可能是详细记录了配置过程的文字说明,包括JDK和Tomcat的安装、环境变量设置、防火墙端口开放等细节。建议按照这个文件的指示操作,确保每一步都正确无误。 需要注意...
Apache Tomcat是一个开源的软件应用服务器,主要用于部署Java Servlet和JavaServer...虽然现在有更新的版本(如8.x和9.x),但理解旧版本的特性可以帮助我们更好地了解Tomcat的历史发展以及它在Web服务器领域中的角色。
【标题】"TomCat5.5 \6.0 两个绿色版" 提供的信息主要涉及的是Apache Tomcat服务器的两个不同版本的绿色免安装版本。Apache Tomcat是一款开源的Java Servlet容器,它实现了JavaServer Pages (JSP)、Java Servlet以及...
2. **性能优化**:与早期版本相比,5.5.x系列在性能上有显著提升,处理请求的速度更快,内存使用效率更高。 3. **安全管理**:包括基于角色的访问控制(RBAC),允许精细的权限分配,确保服务器的安全运行。 4. **...
Tomcat 5.5.x系列是Tomcat的一个较旧版本,发布于2008年,支持Java Servlet 2.4和JSP 2.0标准。在这个版本中,主要的特性包括: 1. **Servlet容器**:Tomcat的核心功能是作为Servlet容器,它负责加载和执行Servlet...
需要注意的是,尽管5.5.x版本的Tomcat在当时是一个稳定的版本,但随着技术的发展,新的Java EE版本和Tomcat版本已经发布,比如现在的Tomcat 9.x和10.x支持Java EE 8和9的标准。因此,对于新的开发和生产环境,建议...
Apache Tomcat 5.5.x系列是Tomcat的一个稳定版本,发布于2006年,它支持Java Servlet 2.4规范和JavaServer Pages 2.0规范。这个版本提供了许多特性,包括对HTTP/1.1协议的支持、支持连接器架构、内置管理工具以及对...
Tomcat 5.5.25是其历史版本之一,虽然现在最新的版本已经更新到了9.x,但5.5系列仍具有一定的学习价值和应用场景,尤其是对于初学者和对低资源需求的应用来说。 Tomcat 5.5.25的特点和改进主要集中在以下几个方面:...
在Tomcat 5.5.x系列中,5.5.15是一个稳定版本,其主要特点包括: 1. **兼容性**:Tomcat 5.5.15遵循Servlet 2.4和JSP 2.0标准,确保与这些版本的Java Web开发技术兼容。这使得开发者能够利用这些规范中的最新功能,...
Apache Tomcat 5.5.x系列是Tomcat的一个稳定版本,发布于2007年,支持Java EE 5规范。这个版本引入了许多改进和新特性,包括更好的性能、安全性增强以及对Servlet 2.5和JSP 2.1规范的支持。 "admin"模块是Tomcat的...
5.5.x系列是Tomcat的一个重要分支,它在性能、稳定性和安全性方面都进行了优化。 在"apache-tomcat-5.5.20"这个压缩包中,通常会包含以下关键组件和目录: 1. **bin**:包含启动和停止Tomcat的脚本,如`catalina....
Tomcat 5.5.x系列是Tomcat的一个重要版本,它在Tomcat 5.5.35中包含了多个稳定性和性能改进。这个版本支持Java Servlet 2.4和JSP 2.0规范,这两个标准为开发动态Web内容提供了强大的框架。以下是关于Apache Tomcat ...
Apache Tomcat的每个版本都有其独特的特性和改进,5.5.x系列是Tomcat的一个稳定分支,发布于2006年,持续维护并修复了许多安全问题和性能优化,直到2018年才停止支持。5.5.27作为该系列的一个版本,可能包含了一些...
- 下载对应的`apache-tomcat-5.5.x-compat.zip`文件,并确保使用正确的JDK版本。 2. **环境变量调整**: - 确保`JAVA_HOME`指向正确的JDK安装目录。 3. **管理权限配置**: - 需要在`Tomcat\conf\tomcat-users....
Tomcat 5.5系列是在2005年发布的,它是对4.x系列的重大改进,引入了对Servlet 2.4和JSP 2.0标准的支持。5.5版本在性能和稳定性上都有所提升,同时增加了一些新功能,如更好的安全管理、更高效的内存管理和对EJB ...
1. **Servlet 2.4 和 JSP 2.0 支持**:Tomcat 5.5.x系列支持Servlet 2.4和JSP 2.0规范,使得开发者可以利用这些规范提供的新功能和改进,如动态EL表达式和自定义标签库。 2. **性能提升**:与之前的版本相比,5.5.8...
尽管5.5.x版本已经过时,但理解它的运作方式对于学习Tomcat的原理以及Web服务的部署很有帮助。对于开发人员来说,知道如何在旧系统上管理和升级Tomcat,或者在需要向后兼容的环境中工作也是必要的技能。而对初学者来...
Apache Tomcat 5.5系列是一个稳定的版本,它支持Servlet 2.4和JSP 2.0规范。版本5.5.28在安全性、性能和稳定性方面都有所提升,包括对已知漏洞的修复。此版本还提供了更好的日志记录和诊断工具,有助于开发者识别和...
Apache Tomcat 5.5.28 是一个广泛使用的...虽然现在最新的版本已经更新至9.x甚至10.x,但5.5.x系列在许多遗留系统中仍发挥着重要作用。了解并熟练掌握Tomcat的配置和管理,对于Java Web开发人员来说是至关重要的技能。
8. **连接器升级**:Tomcat 5.5.x系列使用了Coyote连接器,相较于早期版本,它提供了更好的性能和更高的并发能力。 9. **JSP和Servlet**:Tomcat 5.5.26支持Servlet 2.4和JSP 2.0标准,这些标准引入了许多新的特性...