rgw2qe 发表于 2015-4-8 08:36:46

Tomcat7的优化配置第一天

首先说下测试环境
虚拟机 CENTOS 6.4
TOMCAT版本 apache-tomcat-7.0.59

tomcat的优化分为2个部分
一个是JVM的优化 一个是tomcat自身的优化
首先是jvm的优化
在tomncat的bin目录下catalina.sh里面有一行类似下的注释
# OS specific support. $var _must_ be set to either true or false.

在这行下面添加如下
JAVA_OPTS="-server -Xms256M -Xmx256M -Xss256K -Djava.awt.headless=true -Dfile.encoding=utf-8 -XX:PermSize=64M -XX:MaxPermSize=128m"
各选项的解释:
-server:一定要作为第一个参数,在多个CPU时性能佳

-Xms:初始Heap大小,使用的最小内存,cpu性能高时此值应设的大一些
一般为物理内存的一半

-Xmx:java heap最大值,使用的最大内存
注:一般情况下Xms和Xmx 都设置成一样大小,对于服务器的高并发比较好。

-XX:PermSize:设定内存的永久保存区域

-XX:MaxPermSize:设定最大内存的永久保存区域

-Xss:每个线程的Stack大小


-Djava.awt.headless=true
这个参数一般我们都是放在最后使用的,这全参数的作用是这样的,有时我们会在我们的J2EE工程中使用一些图表工具如:jfreechart,用于在web网页输出GIF/JPG等流,在winodws环境下,一般我们的app server在输出图形时不会碰到什么问题,但是在linux/unix环境下经常会碰到一个exception导致你在winodws开发环境下图片显示的好好可是在linux/unix下却显示不出来,因此加上这个参数以免避这样的情况出现。


修改系统当前open files的大小
ulimit -a 可以查看
默认是1024
文件系统最大可打开文件数:cat /proc/sys/fs/file-max
1、   在vi /etc/security/limits.conf文件中设置最大打开文件数 添加:

*      soft    nofile         65535      

*      hard    nofile      65535

重启机器用ulimit -a 查看 是否生效

安装Tomcat的Apr,提升性能

发现 Tomcat 可以用 Apache Portable Runtime 来提供更强性能,提升Web静态页面的处理能力,不再需要专门的Web Server来处理静态页面了。apr 与 tomcat-native 提供更好的伸缩性、性能和集成到本地服务器技术。

第一步、安装openssl开发库
yum install -y openssl-devel

第二步、安装apr,apr-iconv,apr-util,tomcat-native

安装apr

cd /usr/local/src/
wgethttp://mirror.bit.edu.cn/apache/apr/apr-1.5.1.tar.gz
tar zxvf apr-1.5.1.tar.gz
cd apr-1.5.1
./configure --prefix=/usr/local/apr
make
make install

注:安装的时候如果出现错误
rm: cannot remove `libtoolT': No such file or directory

如下解决:
$RM "$cfgfile" 前面加#注释掉
然后再
./configure --prefix=/usr/local/apr

安装apr-iconv
cd /usr/local/src/
wget http://mirror.bit.edu.cn/apache/apr/apr-iconv-1.2.1.tar.gz
tar -zxvf apr-iconv-1.2.1.tar.gz
cd apr-iconv-1.2.1
./configure --prefix=/usr/local/apr-iconv --with-apr=/usr/local/apr
make
make install

安装apr-iconv
cd /usr/local/src/
wget http://mirror.bit.edu.cn/apache/apr/apr-iconv-1.2.1.tar.gz
tar -zxvf apr-iconv-1.2.1.tar.gz
cd apr-iconv-1.2.1
./configure --prefix=/usr/local/apr-iconv --with-apr=/usr/local/apr
make
make install

安装tomcat-native
cd /usr/local/tomcat7/bin   
tar zxvf tomcat-native.tar.gz
cd tomcat-native-1.1.32-src/jni/native   
./configure --with-apr=/usr/local/apr
make   
make install

设置 apr 的环境变量
cd /usr/local/tomcat1/bin
vi catalina.sh
#!/bin/sh

LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/apr/lib
export LD_LIBRARY_PATH

启动 tomcat 后, 看日志:
bin/startup.sh

head logs/catalina.out
可以看到以下结果:

在高并发下会让性能有明显提升。安装完成后重启即可生效。
如使用默认protocal就是apr,但最好把将protocol
修改成org.apache.coyote.http11.Http11AprProtocol,会更加明确。
cd /usr/local/tomcat7/conf
vi server.xml
修改 如下 所示:

这里使用的共享连接器池,可以供其他的连接器使用,省的没加一个连接器 都要重新配置。
下面用ab进行测试
yum install httpd-tools

ab -kc 1000 -n 10000 http://localhost:8080/

这个指令会使用1000个并发,进行连接10000次。结果如下:

可以适当修改连接器池的属性
maxThreads="30000"
minSpareThreads="512"
maxSpareThreads="2048"
在进行测试,效果应该会更好。



页: [1]
查看完整版本: Tomcat7的优化配置第一天