设为首页 收藏本站
查看: 701|回复: 0

[经验分享] Tomcat 调优

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-5 09:42:56 | 显示全部楼层 |阅读模式
一、tomcat的三种运行模式

    Tomcat的连接器(connector)有三种运行模式

    bio模式(blocking I/O):

        阻塞式I/O操作,默认就是该种运行模式,也是三种运行模式中性能最低的一种

        

    nio模式(new I/O):

        Java nio是一个基于缓冲区、并能提供非阻塞I/O操作的Java API,相比bio具有更好的运行并发性能

        

        <Connector port="8080" protocol="HTTP/1.1"

        connectionTimeout="20000"

        redirectPort="8443" />

        中的protocol属性值改为org.apache.coyote.http11.Http11NioProtocol即可:

        <Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"

        connectionTimeout="20000"

        redirectPort="8443" />

    apr

apr(Apache Portable Runtime/Apache可移植运行时),是Apache HTTP服务器的支持库。你可以简单地理解为,Tomcat将以JNI的形式调用Apache HTTP服务器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高Tomcat对静态文件的处理性能。 Tomcat apr也是在Tomcat上运行高并发应用的首选模式,此前的版本配置apr模式

   

默认情况下是bio模式,介绍下怎么更换成apr模式:

[iyunv@web]#yum install -y apr apr-util apr-devel

[iyunv@web]# cd /data/node1/bin

[iyunv@web bin]# tar -zxvf tomcat-native.tar.gz

[iyunv@web bin]# cd tomcat-native-1.1.32-src/jni/native/

[iyunv@web native]# ./configure --with-apr=/usr/bin/apr-1-config --with-ssl=/usr/include/openssl/

[iyunv@web native]# make && make install

tomcat和apr库整合,需要修改shell脚本文件catalina.sh

[iyunv@web node1]# vim /data/tomcat/bin/catalina.sh +99

JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:+DisableExplicitGC"  

cygwin=false

darwin=false

CATALINA_OPTS="-Djava.library.path=/usr/local/apr/lib"

os400=false

   

   

二、安全优化

    一、修改tomcat默认端口8080

    二、修改shutdown默认端口和名称

        <Server port="8005" shutdown="SHUTDOWN">

        当任何人telnet到tomcat服务的8005端口后输入"SHUTDOWN"即可关闭tomcat服务,从安全角度考虑,可将端口和shutdown的名称进行修改

    三、8009端口是tomcat和apache的mod_proxy_ajp,mod_jk沟通的端口,没用到就关了。在tomcat的配置文件server.xml中这段注释掉:

<!--

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

    -->

三、性能优化

内存调优:

提高JVM内存
1
2
   
vim $TOMCAT_HOME/bin/catalina.sh
JAVA_OPTS="-server -Xms1024m -Xmx1024m -Xss128k -XX:NewSize=512m -XX:MaxNewSize=512m -XX:PermSize=512M -XX:MaxPermSize=512m -Djava.awt.headless=true -Dfile.encoding=UTF-8"

   

参数详解:

server:一定要作为第一个参数,在多个CPU时性能佳

-Xms:初始Heap大小,使用的最小内存,cpu性能高时此值应设的大一些,最好和-Xmx设置一样大,避免内存不够时重新申请分配

-Xmx:java heap最大值,使用的最大内存

上面两个值是分配JVM的最小和最大内存,取决于硬件物理内存的大小,建议均设为物理内存的一半。

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

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

-XX:MaxNewSize:

-Xss 15120 这使得每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k.

+XX:AggressiveHeap 会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。

-Xss:每个线程的Stack大小

-verbose:gc 现实垃圾收集信息

-Xloggc:gc.log 指定垃圾收集日志文件

-Xmn:young generation的heap大小,一般设置为Xmx的3、4分之一

-XX:+UseParNewGC :缩短minor收集的时间

-XX:+UseConcMarkSweepGC :缩短major收集的时间


线程调优

优化tomcat服务器中的server.xml配置文件,在配置文件中找到Connector port="8080",然后做如下修改:


<Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol"

               connectionTimeout="20000"

               redirectPort="8443"

               enableLookups="false"

               acceptCount="50"

               minProcessors="20"

               maxProcessors="200"

               maxThreads="400"

               minSpareThreads="25"

               maxSpareThreads="75"

               URIEncoding="utf-8"

           useBodyEncodingForURI="true"

            server="Tomcat App Srv 1.0"/>

参数详解:

connnectionTimeout: 网络连接超时,默认值20000,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。(本系统由于与后台系统接口超时时间较长,使用设置为60000)

redirectPort: 如果Connector支持非SSL请求,在收到一个要求使用SSL传输的请求以后,Catalina会自动将该请求重定向到这里指定的端口号。

enableLookups: 是否反查域名,默认值为true。为了提高处理能力,应设置为false

acceptCount: 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。默认值10。

minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10

maxProcessors:最大连接线程数,即:并发处理的最大请求数,默认值为75

maxThreads: Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。默认值200。 可以根据机器的时期性能和内存大小调整,一般可以在400-500。最大可以在800左右。  

minSpareThreads: Tomcat初始化时创建的线程数。默认值4。

maxSpareThreads: 一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值50。

URIEncoding: URI编码用于解码字节字符的格式,显示中文,使用UTF-8即可

useBodyEncodingForURI="true"同URLEncoding参数一样。解决tomcat乱码问题

server="Tomcat App Srv 1.0":修改tomcat的版本信息


应用部署调优:

<Host name="localhost" autoDeploy="false" unpackWARs="false" reloadable="false" appBase="webapps">

autoDeploy="false":关闭自动部署,true表示自动部署

unpackWARs="false":关闭自动解压,直接从war包运行,true表示解压

reloadable="false":true表示修改后自动重新加载,false相反



四、添加到开机自启动

   

#!/bin/bash

    # chkconfig: - 96 14

    # description: Tht Apache Tomcat Servlet/JSP container.

    #

    export JAVA_HOME=/data/jdk1.7.0_71    #java安装路径

    export CATALINA_HOME=/data/tomcat    #tomcat 安装路径

    exec /data/tomcat/bin/catalina.sh $*


chmod o+x /etc/init.d/tomcat

chkconfig --add tomcat

chkconfig node1 on

chkconfig --list node1

node1           0:off   1:off   2:on    3:on    4:on    5:on    6:off

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-135300-1-1.html 上篇帖子: Tomcat的基础知识和一些应用,session cluster和session server 下篇帖子: tomcat 日志按天分割
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表