284354749 发表于 2018-12-3 07:42:21

Tomcat 调优

  一、tomcat的三种运行模式
  Tomcat的连接器(connector)有三种运行模式
  bio模式(blocking I/O):
  阻塞式I/O操作,默认就是该种运行模式,也是三种运行模式中性能最低的一种
  nio模式(new I/O):
  Java nio是一个基于缓冲区、并能提供非阻塞I/O操作的Java API,相比bio具有更好的运行并发性能
  
  中的protocol属性值改为org.apache.coyote.http11.Http11NioProtocol即可:
  
  apr
  apr(Apache Portable Runtime/Apache可移植运行时),是Apache HTTP服务器的支持库。你可以简单地理解为,Tomcat将以JNI的形式调用Apache HTTP服务器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高Tomcat对静态文件的处理性能。 Tomcat apr也是在Tomcat上运行高并发应用的首选模式,此前的版本配置apr模式
  默认情况下是bio模式,介绍下怎么更换成apr模式:
  #yum install -y apr apr-util apr-devel
  # cd /data/node1/bin
  # tar -zxvf tomcat-native.tar.gz
  # cd tomcat-native-1.1.32-src/jni/native/
  # ./configure --with-apr=/usr/bin/apr-1-config --with-ssl=/usr/include/openssl/
  # make && make install
  # vim /etc/profile
  添加以下内容
  export LD_LIBRARY_PATH=/usr/local/apr/lib
  tomcat和apr库整合,需要修改shell脚本文件catalina.sh
  # 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默认端口和名称
  
  当任何人telnet到tomcat服务的8005端口后输入"SHUTDOWN"即可关闭tomcat服务,从安全角度考虑,可将端口和shutdown的名称进行修改
  三、8009端口是tomcat和apache的mod_proxy_ajp,mod_jk沟通的端口,没用到就关了。在tomcat的配置文件server.xml中这段注释掉:
  
  三、性能优化
  内存调优:
  提高JVM内存
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",然后做如下修改:
  
  参数详解:
  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的版本信息
  应用部署调优:

    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
  转载参考:http://www.zhetao.com/content425#0-tsina-1-23453-397232819ff9a47a7b7e80a40613cfe1


页: [1]
查看完整版本: Tomcat 调优