Tomcat

一、Tomcat体系架构

1.1 Tomcat介绍

Tomcat 是一个免费的、开源的、轻量级的Web应用服务器。

Tomcat8.5的特点

	支持Servlet3.1 	
	默认采用NIO,移除BIO 	
	支持NIO2(AIO,异步非阻塞IO) 	
	支持HTTP/2协议
	默认采用异步日志处理

1.2 Tomcat启动方式

  	一般启动:startup.bat/sh 
	 嵌入式启动:springboot 
	 Debug启动

1.3 Tomcat项目部署

  1. 隐式部署

    直接将文件夹、war、jar放到webapps目录,tomcat会根据文件夹名称自动生成虚拟路径。

    特点:部署简单。

    缺点:项目修改需要重启Tomcat。

  2. 显示部署

    显示部署分为两种:

    1. 添加context元素

    在配置文件(server.xml)的Host标签下加入Context标签。

    xml 复制代码
    <Context path="/comet" docBase="D:\work_tomcat\ref-comet.war" />

    2)新建xml文件

    在/conf/Catalina/localhost文件夹下创建xml文件(访问路径为文件名)。

    例如:demo.xml,内容为:

    xml 复制代码
    <Context docBase="D:\work_tomcat\ref-comet" />

1.4 Tomcat目录结构

bin目录

startup:检查catalina执行所需环境,并调用catalina启动tomcat。

catalina:真正执行启动,可以在该文件中设置虚拟机参数。

shutdown:停止tomcat。

version:查看版本号。

configtest:校验tomcat配置文件server.xml格式、内容等是否合法。

server:安装tomcat服务。安装后可以用系统服务的方式启动。

webapps 目录

存放web项目的目录,每一个文件夹代表一个项目。tomcat安装后存在的文件夹属于tomcat默认项目,其中ROOT项目在访问时不需要加项目名称。

lib目录

tomcat类库,这个目录下的jar部署在该tomcat下的所有项目都可以共享。

work目录

存放项目运行时生成的文件。

temp目录

存放临时文件,tomcat停止后会删除。

logs目录

存放tomcat日志文件。

localhost.xx.log:web应用的内部程序日志。

catalina.xx.log:控制台日志。

host-manager.xx.log:tomcat管理页面host-manager项目操作日志。

localhost_access_log_xx.log:tomcat访问日志。

conf目录

server.xml:tomcat配置文件。

web.xml:tomcat中所有应用默认的部署描述文件,定义了基础的Servlet和MIME映射。如果部署的应用不包含web.xml,tomcat将使用该文件初始化部署描述。

context.xml:定义所有web应用需要加载的Context配置,如果web应用指定了自己的context.xml,该文件将被覆盖。

tomcat-users.xml:配置tomcat用户信息。

1.5 Tomcat 组件

1.5.1 Server

顶级组件,代表tomcat运行的实例。

1.5.2 Service

一个Server可以包含多个Service。

1.5.3 Connector

连接器,监听转换socket请求,将请求交给Container处理,支持不同协议和不同的IO方式。

1.5.4 Container

表示能够执行客户请求并返回响应的一类对象。不同级别的容器有:Engine、Host、Context、Wrapper。

1.5.5 Engine

整个Servlet引擎,最高级的容器对象。

1.5.6 Host

Servlet引擎中的虚拟机,主要与域名有关,一个服务器有多个域名,可以使用多个host。

1.5.7 Context

代表Servlet的Context,它具备了Servlet运行的基本环境,表示web应用程序本身。

1.5.8 Wrapper

用于表示web应用中定义的Servlet。

1.5.9 Executor

tomcat组件间可以共享的线程池。

二、Tomcat优化

2.1 server.xml优化

tomcat配置的优化,可参考tomcat默认管理页面(http://localhost:8080)中的TomcatXX Configuration。

  1. Connector 连接器优化

    IO模型优化

    xml 复制代码
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"redirectPort="8443" />

    protocol 可选参数:

    org.apache.coyote.http11.Http11Protocol - blocking Java connector

    org.apache.coyote.http11.Http11NioProtocol - non blocking Java NIO connector

    org.apache.coyote.http11.Http11Nio2Protocol - non blocking Java NIO2 connector

    org.apache.coyote.http11.Http11AprProtocol - the APR/native connector.2)配置线程池 Executor

  2. 配置线程池 Executor

xml 复制代码
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
        maxThreads="150" minSpareThreads="4"/>      
xml 复制代码
 <Connector executor="tomcatThreadPool"
               port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
  1. 去除tomcat访问 记录

  2. 关闭自动重载,热部署方式

xml 复制代码
<Context path="/comet" docBase="D:\work_tomcat\ref-comet.war" reloadable="false" />
相关推荐
激流丶7 分钟前
【Kafka 实战】如何解决Kafka Topic数量过多带来的性能问题?
java·大数据·kafka·topic
Themberfue11 分钟前
Java多线程详解⑤(全程干货!!!)线程安全问题 || 锁 || synchronized
java·开发语言·线程·多线程·synchronized·
让学习成为一种生活方式28 分钟前
R包下载太慢安装中止的解决策略-R语言003
java·数据库·r语言
晨曦_子画33 分钟前
编程语言之战:AI 之后的 Kotlin 与 Java
android·java·开发语言·人工智能·kotlin
南宫生1 小时前
贪心算法习题其三【力扣】【算法学习day.20】
java·数据结构·学习·算法·leetcode·贪心算法
Heavydrink1 小时前
HTTP动词与状态码
java
ktkiko111 小时前
Java中的远程方法调用——RPC详解
java·开发语言·rpc
计算机-秋大田2 小时前
基于Spring Boot的船舶监造系统的设计与实现,LW+源码+讲解
java·论文阅读·spring boot·后端·vue
神里大人2 小时前
idea、pycharm等软件的文件名红色怎么变绿色
java·pycharm·intellij-idea
小冉在学习2 小时前
day53 图论章节刷题Part05(并查集理论基础、寻找存在的路径)
java·算法·图论