GC日志

一.生成GC日志
-XX:+UseG1GC 代表使用G1垃圾收集器
-XX:MaxGCPauseMillis=100 垃圾收集最大停顿时间
-Xmx256m 代表堆内存最大大小
-XX:+PrintGCDetails 输出GC详细信息
-XX:+PrintGCTimeStamps 打印GC时间戳
-XX:+PrintGCDateStamps
-XX:+PrintHeapAtGC 代表执行GC前和之后堆内存状态
-Xloggc:C:\Users\FLC\Desktop\授课内容\授课资料\Y2170\JVM专题\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、 下载并安装

gc日志路径 java gc日志默认路径_tomcat

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的内容

gc日志路径 java gc日志默认路径_tomcat_02

<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>

gc日志路径 java gc日志默认路径_tomcat_02

  5 启动tomcat

    5.1进入tomcat的bin目录

1


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


    5.2 启动

1


./startup.sh


    5.3 打开浏览器测试访问

http://192.168.138.187:8080/

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

      

gc日志路径 java gc日志默认路径_apache_04

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

      

gc日志路径 java gc日志默认路径_gc日志路径 java_05

tomcat配置优化

  1.6 禁用AJP连接

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

      

gc日志路径 java gc日志默认路径_apache_06

     1.6.1 什么是AJP呢?

      AJP(Apache JServer Protocol)

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

      

gc日志路径 java gc日志默认路径_xml文件_07

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

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

      

gc日志路径 java gc日志默认路径_apache_08

    1.6.3 重启tomcat,查看效果

      

gc日志路径 java gc日志默认路径_tomcat_09

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

  1.7 执行器(线程池)

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

    1.7.1 修改server.xml文件

      将注释打开

      

gc日志路径 java gc日志默认路径_xml文件_10

 

<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"/>

      

gc日志路径 java gc日志默认路径_tomcat_11

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

      

gc日志路径 java gc日志默认路径_xml文件_12

       在页面中显示最大线程数为-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,查看效果

      

gc日志路径 java gc日志默认路径_tomcat_13