14.性能优化-优化-软件配置优化

Tomcat性能调优指南
本文详细介绍如何通过调整Tomcat线程池、采用NIO、配置JMX远程管理、优化JVM参数、设置C3P0连接池及调整MySQL最大连接数等手段,提升Tomcat服务器性能。
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
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值