Tomcat 优化

时间:2023-01-13 17:14:05

1.apr 
许多朋友可能在启动tomcat的时候都会看到类似这样的信息:

引用
org.apache.catalina.core.AprLifecycleListener init 
信息: The Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:\Java\jre\bin;.;C:\WINDOWS\Sun\Java\bin;C:\WINDOWS\system32;C:\WINDOWS

出现这种情况是这表示没有找到APR 
简要解决办法:去 http://tomcat.heanet.ie/native/ 下载编译好的tcnative-1.dll文件,目前最新为1.1.14,拷贝至jdk\bin下,再启动就可以成功加载APR了。

引用
org.apache.catalina.core.AprLifecycleListener init 
信息: Loaded Apache Tomcat Native library 1.1.14. 
org.apache.catalina.core.AprLifecycleListener init 
信息: APR capabilities: IPv6 [false], sendfile [true], accept filters [false], random [true].

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

  1. URIEncoding="UTF-8"

解决方法如下: 
原始部分 
8080端口上

  1. <Connector port="8080" protocol="HTTP/1.1"
  2. connectionTimeout="20000"
  3. redirectPort="8443" />

修改后

  1. <Connector port="8080" protocol="HTTP/1.1"
  2. connectionTimeout="20000"
  3. redirectPort="8443" URIEncoding="UTF-8" />

8009端口 ajp跳转服务上,关于这个端口在apache http 做跳转时,要相当注意

  1. <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

修改后

  1. <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" URIEncoding="UTF-8" />

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

3.设置Tomcat管理员帐号 
修改tomcat-users.xml文件,在</tomcat-users>的标签前添加一行

  1. <user username="tomcat" password="tomcat" roles="admin,manager"/>

让tomcat用户拥有管理员权限。

4.设置SSL 
首先,我们要创建密钥:

  1. keytool -genkey -alias tomcat -keyalg RSA

此时,用户主目录下会生成一个.keystore文件。 
然后,我们配置server.xml文件,找到SSLEnabled="true"所在的标签,将其解除注释,同时填补两个属性: 
    1.keystoreFile="C:/Users/Zlex/.keystore" 
    2.keystorePass="123456" 
keystoreFile 指的是你的密钥文件存储的路径,keystorePass指的是你的密码。 
举例如下:

  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/Zlex/.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/直接访问。 
需要双向认证?参考如下内容:

  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" />

其中,

  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压缩加速服务器响应速度

只需要配置:

  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压缩支持Tomcat 优化

6.设置静态页面编码 
修改web.xml 
加入如下内容,是*.hml、*.html静态页面默认字符集编码为UTF-8

  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进行配置:

    1. JAVA_OPTS="-Xms512m -Xmx512m -XX:MaxPermSize=256m -Dfile.encoding=UTF-8 -Dsun.jnu.encoding=UTF-8"