1.Tomcat线程池
修改tomcat的server.xml文件:
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" maxThreads="1200" minSpareThreads="300" maxSpareThreads="500" acceptCount="1500" />
maxThreads --最大的线程数量,默认值200。允许的最大线程数受操作系统限制。
minSpareThreads --最小空闲线程数。如果空闲线程小于此值,则一次性创建这个数量的空闲线程。默认值25
maxSpareThreads --最大空闲线程数。如果空闲线程超过此值,会将超出的线程关闭。默认值50
acceptCount --所有线程都使用时,新请求将放入到请求队列中,该值就是排队的请求数,超过该值的请求将被拒绝。默认值100
maxIdleTime --关闭空闲线程的等待时间,默认值60000ms。
2.Tomcat NIO
将默认的BIO改为NIO。
1)修改server.xml
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="45000"
redirectPort="8443"/>
2) 修改catalina.sh的内容头加上oracle jdk在linux平台对epoll实现支持
CATALINA_OPTS='-Djava.nio.channels.spi.SelectorProvider=sun.nio.ch.EPollSelectorProvider'
3.JMX远程
修改catalina.sh:
JAVA_OPTS="-Djava.nio.channels.spi.SelectorProvider=sun.nio.ch.EPollSelectorProvider -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=192.168.137.200"
4.JVM参数设置
修改catalina.sh:
JAVA_OPTS="-XX:PermSize=30M -XX:MaxPermSize=60M -Xss265k -Xms490m -Xmx490m -Xmn245m -Xverify:none -XX:MaxTenuringThreshold=50 -XX:+UseFastAccessorMethods -XX:+UseAdaptiveSizePolicy "
5.C3p0连接池
1)修改server.xml
将下面内容加到<GlobalNamingResources>中
<Resource auth="Container"
description="DB Connection"
driverClass="com.mysql.jdbc.Driver"
maxPoolSize="500"
minPoolSize="200"
initialPoolSize="200"
acquireIncrement="2"
checkoutTimeout="100"
maxIdleTime="60"
maxStatements="0"
name="jdbc/performance"
user="root"
password="password"
factory="org.apache.naming.factory.BeanFactory"
type="com.mchange.v2.c3p0.ComboPooledDataSource"
jdbcUrl="jdbc:mysql://localhost:3306/sid " />
2)修改context.xml
将下面内容加到<Context>中
<ResourceLink name="jdbc/performance" global="jdbc/performance" type="javax.sql.DataSource"/>
3)将c3p0-0.9.2.1.jar &mchange-commons-java-0.2.3.4.jar & mysql-connector-java-5.1.7-bin.jar拷贝到tomcat/lib目录下
6.mysql配置最大连接数
修改my.cnf
可通过#find / -name my.cnf查找my.cnf的目录
[mysqld]
max_connections=1500
7.参考资料
http://suhuanzheng7784877.iteye.com/blog/2026927
http://ycsk.iteye.com/blog/657796
http://blog.chinaunix.net/uid-12115233-id-3358004.html
http://blog.youkuaiyun.com/linlzk/article/details/7761195
修改tomcat的server.xml文件:
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" maxThreads="1200" minSpareThreads="300" maxSpareThreads="500" acceptCount="1500" />
maxThreads --最大的线程数量,默认值200。允许的最大线程数受操作系统限制。
minSpareThreads --最小空闲线程数。如果空闲线程小于此值,则一次性创建这个数量的空闲线程。默认值25
maxSpareThreads --最大空闲线程数。如果空闲线程超过此值,会将超出的线程关闭。默认值50
acceptCount --所有线程都使用时,新请求将放入到请求队列中,该值就是排队的请求数,超过该值的请求将被拒绝。默认值100
maxIdleTime --关闭空闲线程的等待时间,默认值60000ms。
2.Tomcat NIO
将默认的BIO改为NIO。
1)修改server.xml
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="45000"
redirectPort="8443"/>
2) 修改catalina.sh的内容头加上oracle jdk在linux平台对epoll实现支持
CATALINA_OPTS='-Djava.nio.channels.spi.SelectorProvider=sun.nio.ch.EPollSelectorProvider'
3.JMX远程
修改catalina.sh:
JAVA_OPTS="-Djava.nio.channels.spi.SelectorProvider=sun.nio.ch.EPollSelectorProvider -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=192.168.137.200"
4.JVM参数设置
修改catalina.sh:
JAVA_OPTS="-XX:PermSize=30M -XX:MaxPermSize=60M -Xss265k -Xms490m -Xmx490m -Xmn245m -Xverify:none -XX:MaxTenuringThreshold=50 -XX:+UseFastAccessorMethods -XX:+UseAdaptiveSizePolicy "
5.C3p0连接池
1)修改server.xml
将下面内容加到<GlobalNamingResources>中
<Resource auth="Container"
description="DB Connection"
driverClass="com.mysql.jdbc.Driver"
maxPoolSize="500"
minPoolSize="200"
initialPoolSize="200"
acquireIncrement="2"
checkoutTimeout="100"
maxIdleTime="60"
maxStatements="0"
name="jdbc/performance"
user="root"
password="password"
factory="org.apache.naming.factory.BeanFactory"
type="com.mchange.v2.c3p0.ComboPooledDataSource"
jdbcUrl="jdbc:mysql://localhost:3306/sid " />
2)修改context.xml
将下面内容加到<Context>中
<ResourceLink name="jdbc/performance" global="jdbc/performance" type="javax.sql.DataSource"/>
3)将c3p0-0.9.2.1.jar &mchange-commons-java-0.2.3.4.jar & mysql-connector-java-5.1.7-bin.jar拷贝到tomcat/lib目录下
6.mysql配置最大连接数
修改my.cnf
可通过#find / -name my.cnf查找my.cnf的目录
[mysqld]
max_connections=1500
7.参考资料
http://suhuanzheng7784877.iteye.com/blog/2026927
http://ycsk.iteye.com/blog/657796
http://blog.chinaunix.net/uid-12115233-id-3358004.html
http://blog.youkuaiyun.com/linlzk/article/details/7761195
Tomcat性能调优指南
本文详细介绍如何通过调整Tomcat线程池、采用NIO、配置JMX远程管理、优化JVM参数、设置C3P0连接池及调整MySQL最大连接数等手段,提升Tomcat服务器性能。

被折叠的 条评论
为什么被折叠?



