zoukankan      html  css  js  c++  java
  • GC日志与Tomcat优化

    GC日志

    一.生成GC日志
    -XX:+UseG1GC 代表使用G1垃圾收集器
    -XX:MaxGCPauseMillis=100 垃圾收集最大停顿时间
    -Xmx256m 代表堆内存最大大小
    -XX:+PrintGCDetails 输出GC详细信息
    -XX:+PrintGCTimeStamps 打印GC时间戳
    -XX:+PrintGCDateStamps
    -XX:+PrintHeapAtGC 代表执行GC前和之后堆内存状态
    -Xloggc:C:UsersFLCDesktop授课内容授课资料Y2170JVM专题gc.log 代表日志输出目录

    二.分析日志文件
    通过gceasy.io官网分析
    1.上传.log文件
    2.点击Analyzer分析

    安装TomCat

    1.1 使用XFTP工具进行文件上传,将tomcat压缩包上传到/usr/local

    1.2 切换到/usr/local目录,然后使用tar -zxvf 解压集合
    1.3 配置Tomcat用户账号和密码
    1.4 找到tomcat解压目录的conf文件夹,找到tomcat-users.xml文件,配置用户和角色信息
    <role rolename="manager"/> <role rolename="manager-gui"/> <role rolename="admin"/> <role rolename="admin-gui"/> <user username="tomcat" password="tomcat" roles="admin-gui,admin,manager-gui,manager"/>
    1.5 tomcat7当中配置了用户名和密码之后直接可以登陆,tomcat8则需要修改webapps/manager/MATE-INF/context.xml文件,将Value注释
    1.6 启动Tomcat
    cd /usr/local/apache-tomcat-8/bin
    ./startup.sh

    ./startup.sh && tail -f ../logs/catalina.out

    2.优化方案:
    2.1 禁用ajp服务(windows中tomcat8版本默认就是禁用的,linux需要手动禁用)
    2.1.1 停止tomcat服务 ./shutdown.sh
    2.1.2 找到conf目录下有一个server.xml文件,找到8009端口的Connector节点,注释该节点
    2.1.3 重启tomcat服务
    2.2 配置执行器(线程池)
    找到server.xml文件,配置线程池,指定8080使用该执行器
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>

    <Connector executor="tomcatThreadPool" port="8080" protocol="HTTP/1.1"
    connectionTimeout="20000"
    redirectPort="8443" />

    2.3 启用运行模式
    Tomcat启动运行模式:
    bio:传统IO,阻塞IO
    nio:非阻塞IO tomcat8默认
    tomcat8中提供一个nio2,性能比NIO要好
    apr:tomcat7当中默认使用

    <Connector executor="tomcatThreadPool" port="8080" protocol="org.apache.coyote.http11.Http11Nio2Protocol" connectionTimeout="20000" redirectPort="8443" />

    1、 下载并安装

    2. 解压文件

    tar -zxvf apache-tomcat-8.5.34.tar.gz

    3. 修改Tomcat的管理用户配置文件

    3.1 进入Tomcat的conf目录下  

    cd apache-tomcat-8.5.34/conf/

    3.2 修改tomcat-users.xml文件

    vim tomcat-users.xml
    

      

    3.3 修改文件的内容如下

      <role rolename="manager"/>
      <role rolename="manager-gui"/>
      <role rolename="admin"/>
      <role rolename="admin-gui"/>
      <user username="tomcat" password="tomcat" roles="admin-gui,admin,manager-gui,manager"/>
    

      

      4. 注意:如果是tomcat7,配置了tomcat用户就可以登录系统了,但是tomcat8中不行,还需要修改另一个配置文件,否则访问不了,提供403

        4.1 修改context.xml文件

    vim webapps/manager/META-INF/context.xml
    

      

        4.2 修改内容如下  注释value的内容

    <Context antiResourceLocking="false" privileged="true" >:
      <!--
      <Valve className="org.apache.catalina.valves.RemoteAddrValve"
             allow="127.d+.d+.d+|::1|0:0:0:0:0:0:0:1" />
      -->
      <Manager sessionAttributeValueClassNameFilter="java.lang. (?:Boolean|Integer|Long|Number|String)|org.apache.catalina.filters.Cs rfPreventionFilter$LruCache(?:$1)?|java.util.(?:Linked)?HashMap"/>
    </Context>
    

      

      5 启动tomcat

        5.1进入tomcat的bin目录

    cd /usr/local/apache-tomcat-8.5.34/bin/
    

      

        5.2 启动

    ./startup.sh
    

      

        5.3 打开浏览器测试访问

    http://192.168.138.187:8080/

        5.4 点击【Server Status】,输入用户名(tomcat),密码进行登录(tomcat)

          

        5.5 成功进入如下页面  即可看到服务器的信息 

          

    tomcat配置优化

      1.6 禁用AJP连接

          在服务状态页面中可以看到,默认状态下会启动AJP服务,并且占用8009端口

          

         1.6.1 什么是AJP呢?

          AJP(Apache JServer Protocol)

          AJPv13协议是面向包的,WEB服务器和Servlet容器通过TCP连接来交互;为了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP连接到servlet容器,并且在多个请求和响应周期过程会重用连接。

          

           我们一般是使用nginx+tomcat的架构,所以用不着AJP协议,所以把AJP连接器禁用;

        1.6.2 修改conf下的server.xml文件,将AJP服务器禁用掉即可;

          

        1.6.3 重启tomcat,查看效果

          

           可以看到AJP服务已经不存在了;

      1.7 执行器(线程池)

        在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能;

        1.7.1 修改server.xml文件

          将注释打开

           

    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>
    

      

        1.7.2 参数说明

          maxThreads:最大并发数,默认设置 150,一般建议在 500 ~ 1000,根据硬件设施和业务来判断

          minSpareThreads:tomcat初始化时创建的线程数,默认是4

          prestartminSpareThreads:在tomcat初始化的时候就初始化minSpareThreads的参数值,如果不等于true,minSpareThreads的值就没啥效果了

          maxQueueSize:最大的等待队列数,超过则拒绝请求

        1.7.3 在Connector中设置executor属性指向上面的执行器

    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
            maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>
    

      

          

        1.7.4 保存退出,重启tomcat,查看效果

          

           在页面中显示最大线程数为-1,这个是正常的,仅仅是显示的问题,实现使用的执行的值;

      1.8 三种运行模式

        1.8.1 tomcat的运行默认有三种:

          bio:默认的模式,性能非常低,没有经过任何优化处理和支持;

          nio:是java SE1.4及后续版本提供的一种新的I/O操作方式。java nio是一个基于缓冲区,并能提供非阻塞I/O操作的java API,因此nio也被看成是non-blocking I/O的缩写。它拥有比传统I/O操作(bio)更好的并发运行性能;

          apr:安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能;

          推荐使用nio,不过,在tomcat8中有最新的nio2,速度更快,建议使用nio2;

        1.8.2 设置nio

    <Connector executor="tomcatThreadPool"
         port="8080" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
         connectionTimeout="20000"
         redirectPort="8443" />
    

      

        1.8.3 重启tomcat,查看效果

          

  • 相关阅读:
    Linux学习笔记-Shell和命令基础
    转载 | 辗转相除法
    C语言字符数组应用示例2:用二维数组输出一个菱形图案
    C语言字符数组应用示例1:编写一个程序,将两个字符串连接起来,不用strcat函数。
    C语言字符数组超细讲解
    C语言二维数组的应用举例
    C语言二维数组超细讲解
    Java同步方法:synchronized到底锁住了谁?
    家乐的深度学习笔记「5」
    工程中的算法应用
  • 原文地址:https://www.cnblogs.com/F017/p/12449688.html
Copyright © 2011-2022 走看看