Tomcat的一些常见问题

1.APR

许多朋友可能在启动tomcat的时候都会看到类似这样的信息: 
引用
2014-10-19 11:52:31 org.apache.catalina.core.AprLifecycleListener init
信息: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: E:/Program Files/Java/jre1.6.0_06/bin;E:/Program Files/apache-tomcat-6.0.29.1/bin

出现这种情况是这表示没有找到APR 
简要解决办法:在网络上下载或者是去  http://tomcat.heanet.ie/native/  下载编译好的tcnative-1.dll文件,目前最新为1.1.27,拷贝至/jdk1.6.0_06/bin和/pache-tomcat-6.0.29/bin目录下,再启动就可以成功加载APR了。 
引用
2014-10-19 11:56:14 org.apache.catalina.core.AprLifecycleListener init
信息: Loaded APR based Apache Tomcat Native library 1.1.19.
2014-10-19 11:56:14 org.apache.catalina.core.AprLifecycleListener init
信息: APR capabilities: IPv6 [true], sendfile [true], accept filters [false], random [true].

2.URIEncoding  
有时候在做开发的时候经常发现文本框输入的中文到了程序中成了乱码,其实是因为在端口监听部分缺少编码。
Xml代码   收藏代码
  1. URIEncoding="UTF-8"   

解决方法如下: 
原始部分 
8080端口上 
Xml代码   收藏代码
  1. <Connector port="8080" protocol="HTTP/1.1"   
  2.                connectionTimeout="20000"   
  3.                redirectPort="8443" />  

修改后 
Xml代码   收藏代码
  1. <Connector port="8080" protocol="HTTP/1.1"   
  2.                connectionTimeout="20000"   
  3.                redirectPort="8443" URIEncoding="UTF-8" />  

8009端口 ajp跳转服务上,关于这个端口在apache http 做跳转时,要相当注意 
Xml代码   收藏代码
  1. <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />  

修改后 
Xml代码   收藏代码
  1. <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" URIEncoding="UTF-8" />  

这样,服务器得到的中文字符就不会再有乱码了。 

3.设置Tomcat管理员帐号 
修改tomcat-users.xml文件,在 </tomcat-users> 的标签前添加一行 
Xml代码   收藏代码
  1. <user username="tomcat" password="tomcat" roles="admin,manager"/>  
让tomcat用户拥有管理员权限。 

4.设置SSL  
首先,我们要创建密钥: 
Shell代码   收藏代码
  1. keytool -genkey -alias tomcat -keyalg RSA  

此时,用户主目录下会生成一个 .keystore 文件。 
然后,我们配置server.xml文件,找到SSLEnabled="true"所在的标签,将其解除注释,同时填补两个属性: 
    1.keystoreFile="C:\Users\Administrator\.keystore" 
    2.keystorePass="123456" 
keystoreFile 指的是你的密钥文件存储的路径,keystorePass指的是你的密码。 
举例如下: 
Xml代码   收藏代码
  1. <!--  
  2.     Define a SSL HTTP/1.1 Connector on port 8443 This connector uses the  
  3.     JSSE configuration, when using APR, the connector should be using the  
  4.     OpenSSL style configuration described in the APR documentation  
  5. -->  
  6. <!-- -->  
  7. <Connector  
  8.     SSLEnabled="true"  
  9.     clientAuth="false"  
  10.     keystoreFile="C:\Users\Administrator\.keystore"  
  11.     keystorePass="123456"  
  12.     maxThreads="150"  
  13.     port="8443"  
  14.     protocol="HTTP/1.1"  
  15.     scheme="https"  
  16.     secure="true"  
  17.     sslProtocol="TLS" />  

最后,重启tomcat,在地址栏中访问  https://localhost:8443/ 。 
将上述 port="8443" 配置改为 port="443" ,可以通过 https://localhost/ 直接访问。 
需要双向认证?参考如下内容: 
Xml代码   收藏代码
  1. <Connector port="443"   
  2.     URIEncoding="UTF-8"   
  3.     useBodyEncodingForURI="true"   
  4.     maxHttpHeaderSize="33192"  
  5.     maxThreads="150"   
  6.     minSpareThreads="25"   
  7.     maxSpareThreads="75"  
  8.     enableLookups="false"  
  9.     disableUploadTimeout="true"   
  10.     acceptCount="100"  
  11.     scheme="https"   
  12.     secure="true"   
  13.     SSLEnabled="true"   
  14.     clientAuth="true"  
  15.     keystoreFile="conf/server.keystore"   
  16.     keystorePass="123456"  
  17.     truststoreFile="conf/ca.p12"   
  18.     truststorePass="123456"  
  19.     truststoreType="PKCS12"  
  20.     sslProtocol="TLS" />   

其中, 
Xml代码   收藏代码
  1. clientAuth="true"  
  2. keystoreFile="conf/server.keystore"   
  3. keystorePass="123456"  
  4. truststoreFile="conf/ca.p12"   
  5. truststorePass="123456"  
  6. truststoreType="PKCS12"  

clientAuth="true" 开启双向认证 
keystoreFile="conf/server.keystore"  指向服务器密钥库 
keystorePass="123456"  服务器密钥库密码 
truststoreFile="conf/ca.p12" 指向CA信任库 
truststorePass="123456" CA信任库密码 
truststoreType="PKCS12" CA信任库格式,除了PKCS#12还有JKS,JKS为java原生默认支持的密钥库格式! 
更多ssl配置访问 http://tomcat.apache.org/tomcat-6.0-doc/ssl-howto.html 。 

5.通过GZIP压缩加速服务器响应速度  

只需要配置: 
Xml代码   收藏代码
  1. <Connector   
  2.               port="8080"   
  3.               protocol="HTTP/1.1"  
  4.               connectionTimeout="20000"  
  5.               redirectPort="443"   
  6.               URIEncoding="UTF-8"  
  7.               compression="on"     
  8.               noCompressionUserAgents="gozilla, traviata"     
  9.               compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain,application/json"   
  10. />    

说说配置细节: 
compression="on"   开启压缩支持 
noCompressionUserAgents="gozilla, traviata"   不压缩的内容 
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain,application/json" 压缩的类型
 

之后进行的访问均可获得GZIP压缩支持 


6.设置静态页面编码  
修改web.xml 
加入如下内容,是*.hml、*.html静态页面默认字符集编码为UTF-8 
Xml代码   收藏代码
  1. <mime-mapping>  
  2.     <extension>htm</extension>  
  3.     <mime-type>text/html;charset=utf-8</mime-type>  
  4. </mime-mapping>  
  5. <mime-mapping>  
  6.     <extension>html</extension>  
  7.     <mime-type>text/html;charset=utf-8</mime-type>  
  8. </mime-mapping>  



7.配置JVM  
找到 JAVA_OPTS 进行配置: 
Java代码   收藏代码
  1. JAVA_OPTS="-Xms512m -Xmx512m -XX:MaxPermSize=256m -Dfile.encoding=UTF-8 -Dsun.jnu.encoding=UTF-8"  





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值