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