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来记录日志

 

 

 

posted @ 2019-03-11 19:50  九号云  阅读(233)  评论(0编辑  收藏  举报