• Tomcat相关


    一:Tomcat文件解析

    /bin:脚本文件目录。(其中sh文件liux上的启动文件,bat文件windows上的启动文件)

    /lib:tomcat的一系列依赖的jar包
     /common/lib:存放所有web项目都可以访问的公共jar包(使用Common类加载器加载)。
     /conf:存放配置文件,最重要的是server.xml。
     /logs:存放日志文件。

    1.catalina.日期.log
      这个主要是记录tomcat启动时候的信息,类似于我们在eclipse中启动服务的时候在控制台看到的信息。在里面可以看到启动的JVM参数以及操作系统等日志信息。如果没有使用log4j等日志机制,系统的的错误信息与打印语句也在这个日志文件中记录。(linux下所有的日志都在catalina.out中)
    2.commons-daemon.日期.log
      这个日期放的估计是利用服务方式启动tomcat作为守护进程的日志记录,因为我的tomcat启动方式是以服务的方式启动的,索引产生这个日志文件记录了服务的启动状态。
    3.host-manager.日期.log
      这个估计是放tomcat的自带的manager项目的日志信息的,也没有看到有什么重要的日志信息
    4.localhost.日期.log
      这个类似于第一种日志,可是信息没有第一种全
    5.localhost_access_log.日期.txt
      这个是存放访问tomcat的请求的所有地址以及请求的路径、时间,请求协议以及返回码等信息(重要)
    6.manager.日志.log
      这个估计也是manager项目专有的日志文件,看不出有什么重要的信息
    7.tomcat7-stderr.日期.log  
      这个是log4j的错误日志,因此在程序中要合理的捕捉异常。
    8.tomcat7-stdout.日期.log  (类似于eclipse的控制台的信息)
      这个是程序中的System语句打印的日志(包括系统抛出的异常),也终于明白了为什么一再强调不能用打印语句进行系统调试
    

    /server/webapps:来管理Tomcat-web服务用的。仅对TOMCAT可见,对所有的WEB APP都不可见(使用Catalina类加载器加载)。

     /shared/lib:仅对所有WEB APP可见,对TOMCAT不可见(使用Shared类加载器加载)。
     /temp:Tomcat运行时候存放临时文件用的。
     /webapps:web应用发布目录。
     /work:Tomcat把各种由jsp生成的servlet文件放在这个目录下。删除后,启动时会自动创建。

     

    二:tomcat的三种部署项目方式

    隐式部署:
    1)webapps目录下 显式部署: 1)conf/server.xml中的Host加入一个Context(指定路径和文件地 址)
    <Context path="/test" docBase="webdemo" debug="0" reloadable="true" />。docBase目录默认使用appBase="webapps"这个目录。也可以是绝对路径。 2)在conf/Catalina/localhost中创建xml文件(热部署),访问路径为文件名

      

    Tomcat启动步骤

    Bootstrap -> catalina -> server -> service -> connector、container等

    三:Tomcat Server处理一个HTTP请求的过程

    1、用户点击网页内容,请求被发送到本机端口8080,被在那里监听的Coyote HTTP/1.1 Connector获得。 
    2、Connector把该请求交给它所在的Service的Engine来处理,并等待Engine的回应。 
    3、Engine获得请求localhost/test/index.jsp,匹配所有的虚拟主机Host。 
    4、Engine匹配到名为localhost的Host(即使匹配不到也把请求交给该Host处理,因为该Host被定义为该Engine的默认主机),名为localhost的Host获得请求/test/index.jsp,匹配它所拥有的所有的Context。Host匹配到路径为/test的Context(如果匹配不到就把该请求交给路径名为“ ”的Context去处理)。 
    5、path=“/test”的Context获得请求/index.jsp,在它的mapping table中寻找出对应的Servlet。Context匹配到URL PATTERN为*.jsp的Servlet,对应于JspServlet类。 
    6、构造HttpServletRequest对象和HttpServletResponse对象,作为参数调用JspServlet的doGet()或doPost().执行业务逻辑、数据存储等程序。 
    7、Context把执行完之后的HttpServletResponse对象返回给Host。 
    8、Host把HttpServletResponse对象返回给Engine。 
    9、Engine把HttpServletResponse对象返回Connector。 
    10、Connector把HttpServletResponse对象返回给客户Browser。
    

      

    四:tomcat的优化

     Tomcat中server.xml优化

    1:连接器模式改为NIO模式
    NIO模式最大化压榨了CPU,把时间片更好利用起来 NIO适合大量长连接


    2:
    关闭自动重载
    <Context docBase="" reloadable="false"/>
    关闭自动重载,默认是true(不同版本中有差异)
    自动加载增加运行开销并且很容易内存溢出

    3:
    配置线程池
    Executor标签中属性
    namePrefix】线程命名前缀
    maxThreads】最大允许线程数
    minSpareThreads】最少空闲线程,相当于初始化的线程,线程池中的线程
    Connector标签中的属性
    executor】对上面Executor标签标签的引用
    
    

     Tomcat中web.xml优化

    Jspservlet开发模式(development)设置为false

    SpringBoot中Tomcat优化

    Maven中Springboot引入Tomcat 
    <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <scope>provided</scope> </dependency>

    1.设置线程池
    server.tomcat.max-threads=1000


    2.关闭Accesslog日志
    server.tomcat.accesslog=false

    当前应用是REST应用(微服务):

    servlet优化
    1.去掉不必要的资源:JspServlet
    2.seesion也可以移除 
    
    
    web.xml优化:
    移除掉AccessLogValve
    valve实现都需要消耗java应用的计算时间,一般我们可以使用nginx来记录日志

     

  • 相关阅读:
    《垃圾回收的算法与实现》——增量式垃圾回收与RC Immix算法
    《垃圾回收的算法与实现》——分代垃圾回收
    《垃圾回收的算法与实现》——保守式GC
    《垃圾回收的算法与实现》——GC标记-压缩算法
    《垃圾回收的算法与实现》——GC复制算法
    《垃圾回收的算法与实现》——引用计数法
    《垃圾回收的算法与实现》——GC标记-清除算法
    《Mysql技术内幕,Innodb存储引擎》——事物
    《Mysql技术内幕,Innodb存储引擎》——锁
    《Mysql技术内幕,Innodb存储引擎》——索引与算法
  • 原文地址:https://www.cnblogs.com/jiuhaoyun/p/10512756.html
Copyright © 2020-2023  润新知