• Tomcat和JVM性能调优


    JVM性能调优:

    Tomcat本身还是运行在JVM上的,通过对JVM参数的调整我们可以使Tomcat拥有更好的性能。目前针对JVM的调优主要有两个方面:内存调优和垃圾回收策略调优。

    所以归纳为以下:

    总体架构

    主要的组件

    执行过程

    tomcat 调优 :
    可以考虑从内存,并发,缓存,安全,网络,系统等进行入手

    内存优化
    修改内存等 JVM相关配置
    Linux下修改TOMCAT_HOME/bin/catalina.sh
    JAVA_OPTS="-server -XX:PermSize=512M -XX:MaxPermSize=1024m -Xms2048m -Xmx2048m
    windows下修改TOMCAT_HOME/bin/catalina.bat
    set JAVA_OPTS=-server -XX:PermSize=512M -XX:MaxPermSize=1024m -Xms2048m -Xmx2048m

    参数介绍

    -server:启用 JDK的 server 版本;
    -Xms:Java虚拟机初始化时堆的最小内存,一般与 Xmx配置为相同值,这样的好处是GC不必再为扩展内存空间而消耗性能;
    -Xmx:Java虚拟机可使用堆的最大内存;
    -XX:PermSize:Java虚拟机永久代大小;
    -XX:MaxPermSize:Java虚拟机永久代大小最大值;

    验证
    可以利用JDK自带的工具进行验证,这些工具都在JAVA_HOME/bin目录下:
    1)jps:用来显示本地的java进程,以及进程号,进程启动的路径等。
    2)jmap:观察运行中的JVM 物理内存的占用情况,包括Heap size , Perm size等。
    进入命令行模式后,进入JAVA_HOME/bin目录下,然后输入jps命令:

    并发优化
    Connector 优化
    Connector是连接器,负责接收客户的请求,以及向客户端回送响应的消息。所以 Connector的优化是重要部分。默认情况下 Tomcat只支持200线程访问,超过这个数量的连接将被等待甚至超时放弃,所以我们需要提高这方面的处理能力。

    调后的配置

    参数说明

    maxThreads 客户请求最大线程数
    minSpareThreads Tomcat初始化时创建的 socket 线程数
    maxSpareThreads Tomcat连接器的最大空闲 socket 线程数
    enableLookups 若设为true, 则支持域名解析,可把 ip 地址解析为主机名
    redirectPort 在需要基于安全通道的场合,把客户请求转发到基于SSL 的 redirectPort 端口
    acceptAccount 监听端口队列最大数,满了之后客户请求会被拒绝(不能小于maxSpareThreads )
    connectionTimeout 连接超时
    minProcessors 服务器创建时的最小处理线程数
    maxProcessors 服务器同时最大处理线程数
    URIEncoding URL统一编码

    缓存优化
    更改后的配置

    参数说明

    compression 打开压缩功能
    compressionMinSize 启用压缩的输出内容大小,这里面默认为2KB
    compressableMimeType 压缩类型
    connectionTimeout 定义建立客户连接超时的时间. 如果为 -1, 表示不限制建立客户连接的时间

    IO优化
    配置

    说明
    1:同步阻塞IO(JAVA BIO) 同步并阻塞,服务器实现模式为一个连接一个线程(one connection one thread 想想都觉得恐怖,线程可是非常宝贵的资源),当然可以通过线程池机制改善.
    2:JAVA NIO:又分为同步非阻塞IO,异步阻塞IO 与BIO最大的区别one request one thread.可以复用同一个线程处理多个connection(多路复用).
    3:,异步非阻塞IO(Java NIO2又叫AIO) 主要与NIO的区别主要是操作系统的底层区别.可以做个比喻:比作快递,NIO就是网购后要自己到官网查下快递是否已经到了(可能是多次),然后自己去取快递;AIO就是快递员送货上门了(不用关注快递进度)。
    BIO方式适用于连接数目比较小且固定的架构,这种方式对服务器资源要求比较高,并发局限于应用中,JDK1.4以前的唯一选择,但程序直观简单易理解.
    NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,JDK1.4开始支持.
    AIO方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,JDK7开始支持.

    开启线程池
    配置

     

     参数说明

    name:线程池名称,用于 Connector中指定。
    namePrefix:所创建的每个线程的名称前缀,一个单独的线程名称为 namePrefix+threadNumber。
    maxThreads:池中最大线程数。
    minSpareThreads:活跃线程数,也就是核心池线程数,这些线程不会被销毁,会一直存在。
    maxIdleTime:线程空闲时间,超过该时间后,空闲线程会被销毁,默认值为6000(1分钟),单位毫秒。
    maxQueueSize:在被执行前最大线程排队数目,默认为Int的最大值,也就是广义的无限。除非特殊情况,这个值不需要更改,否则会有请求不会被处理的情况发生。
    prestartminSpareThreads:启动线程池时是否启动 minSpareThreads部分线程。默认值为false,即不启动。
    threadPriority:线程池中线程优先级,默认值为5,值从1到10。
    className:线程池实现类,未指定情况下,默认实现类为org.apache.catalina.core.StandardThreadExecutor。如果想使用自定义线程池首先需要实现 org.apache.catalina.Executor接口。

    添加Listener
    另一个影响Tomcat 性能的因素是内存泄露。Server标签中可以配置多个Listener,其中 JreMemoryLeakPreventionListener是用来预防JRE内存泄漏。此Listener只需在Server标签中配置即可,默认情况下无需配置,已经添加在 Server中。

  • 相关阅读:
    WebService 通过POST方式访问时候,因 URL 意外地以“/方法名”结束,请求格式无法识别 解决办法
    SQL Server 触发器
    JS数据类型转换
    .net注册到IIS
    SQL Server 常用sql操作语句
    浅解DLL
    有关注册表API函数
    [原]惜 时
    图解双机共享ADSL上网
    如何在C#中使用全局鼠标、键盘Hook
  • 原文地址:https://www.cnblogs.com/47Gamer/p/13036261.html
Copyright © 2020-2023  润新知