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

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.csdn.net/linlzk/article/details/7761195

你可能感兴趣的:(软件配置,性能优化)