目录
一. Tomcat的介绍
1.2 Tomcat核心组件
1.2.1 核心组件的作用
1.3 servlet简介
1.4 JSP介绍
1.5 Tomcat功能组件结构
1.6 Tomcat请求过程
二.Tomcat服务部署
2..2 安装JDK编辑编辑编辑
2.3 设置JDK环境变量编辑编辑
2.5 优化tomcat启动速度
2.6 tomcat虚拟主机配置
2.6.1 创建kgc 和 benet 项目目录和文件
2.6.2 修改tomcat主配置文件server.xml
2.6.3 重启tomcat服务编辑2.6.4 设置域名解析
2.6.5 测试
三. Tomcat优化
3.1 Tomcat配置文件参数优化
一. Tomcat的介绍
Tomcat是一款我们平时开发过程中最常用到的Servlet容器。本系列博客会记录Tomcat(以Tomcat 7为列)的整体架构、核心组件、IO线程模型、请求在Tomcat内部的流转过程以及一些Tomcat调优的相关知识点。力求能达到以下几个目的:
- 更加熟悉Tomcat的工作机制,工作中遇到Tomcat相关问题能够快速定位,从源头来解决;
- 对于一些高并发场景能够对Tomcat进行调优;
- 通过对Tomcat源码的分析,吸收一些Tomcat的设计的理念,应用到自己的软件开发过程中。
1.2 Tomcat核心组件
web容器, Servlet容器,JSP容器
1.2.1 核心组件的作用
web容器:①接受,响应请求 ② 展示动态页面人口,出口
serverlet容器:借助catalina来执行serverlet代码(动态任务执行的标准格式)
jsp容器: 翻译java----->servlet
1.3 servlet简介
Servlet 是Java Servlet 的简称,可以理解为是一个服务连接器,是用 Java 编写的服务器端程序,具有独立于平台和协议的特性, 简单的理解:servlet 就是一个中间件,包含了接口和方法,将客户端和数据库连接,从而实现动态网页的创建
1.4 JSP介绍
1. JSP 全称 Java Server Pages,是一种动态网页开发技术。它使用 JSP 标签在HTML网页中插 入 Java 代码。标签通常以 <% 开头,以 %> 结束。
2. JSP 是一种 Java servlet,主要用于实现 Java web 应用程序的用户界面部分。
3. JSP 通过网页表单获取用户输入数据、访问数据库及其他数据源,然后动态地创建网页。
1.5 Tomcat功能组件结构
Tomcat 的核心功能有两个,分别是负责接收和反馈外部请求的连接器 Connector,和负责处理请求的容器 Container。 其中连接器和容器相辅相成,一起构成了基本的 web 服务 Service。每个 Tomcat 服务器可以管理多个 Service。
1. Connector:负责对外接收和响应请求。它是Tomcat与外界的交通枢纽,监听端口接收外界请 求,并将请求处理后传递给容器做业务处理,最后将容器处理后的结果响应给外界。
2. Container:负责对内处理业务逻辑。其内部由 Engine、Host、Context和Wrapper 四个容器组 成,用于管理和调用 Servlet 相关逻辑。
3. Service:对外提供的 Web 服务
Container 结构分析:
每个 Service 会包含一个 Container 容器。在 Container 内部包含了 4 个子容器:
4个子容器的作用分别是:
1. Engine:引擎,用来管理多个虚拟主机,一个 Service 最多只能有一个 Engine;
2. Host:代表一个虚拟主机,也可以叫站点,通过配置 Host 就可以添加站点;
3. Context:代表一个 Web 应用,包含多个 Servlet 封装器;
4. Wrapper:封装器,容器的最底层。每一 Wrapper 封装着一个 Servlet,负责对象实例的创建 执行和销毁功能。
Engine、Host、Context 和 Wrapper,这四个容器之间属于父子关系。
容器 由一个引擎可以管理多个虚拟主机。每个虚拟主机可以管理多个 Web 应用。每个 Web 应用会有多个 Servlet 封装器。
1.6 Tomcat请求过程
1、用户在浏览器中输入网址,请求被发送到本机端口 8080,被在那里监听的 Connector 获得;
2、Connector 把该请求交给它所在的 Service 的 Engine(Container)来处理,并等待 Engine 的 回应;
3、请求在 Engine、Host、Context 和 Wrapper 这四个容器之间层层调用,最后在 Servlet 中执行 对应的业务逻辑、数据存储等。
4、执行完之后的请求响应在 Context、Host、Engine 容器之间层层返回,最后返回给 Connector,并通过 Connector 返回给客户端。
二.Tomcat服务部署
在部署 Tomcat 之前必须安装好 jdk,因为 jdk 是 Tomcat 运行的必要环境。
1. CLASSPATH:编译、运行Java程序时,JRE会去该变量指定的路径中搜索所需的类(.class) 文件。
2. JDK :java development kit (java开发工具)
3. JRE :java runtime environment (java运行时环境)
4. JVM :java virtuak machine (java虚拟机),使java程序可以在多种平台上运行class文件
2.1 关闭防火墙,将安装Tomcat所需软件包转到/opt目录下
2..2 安装JDK
2.3 设置JDK环境变量
编写java文件验证
启动tomcat 浏览器访问Tomcat的默认主页 http://172.16.18.5:8080(本机IP)
2.5 优化tomcat启动速度
第一次启动tomcat可能会发现 Tomcat 启动很慢,默认情况下可能会需要几十秒,可以修改jdk参数进行改。
tomcat主要目录说明bin:存放启动和关闭 Tomcat 的脚本文件,如 catalina.sh、startup.sh、shutdown.sh
conf:存放 Tomcat 服务器的各种配置文件,如主配置文件 server.xml 和 应用默认的部署描述文 件web.xml
lib:存放 Tomcat 运行需要的库文件的 jar 包,一般不作任何改动
logs:存放 Tomcat 执行时的日志
temp:存放 Tomcat 运行时产生的文件
webapps:存放 Tomcat 默认的 Web 应用项目资源的目录
work:Tomcat 的工作目录,存放 Web 应用代码生成和编译文件
tomcat 8080 http端口
tomcat 8443 https端口
tomcat 8005端口是用来关闭进程所用
tomcat 8009转发端口
负责和其它http服务器建立连接
2.6 tomcat虚拟主机配置
很多时候公司会有多个项目需要运行,一般不会是在一台服务器上运行多个 Tomcat 服务,这样会消耗太多的系统资源。此时, 就需要使用到 Tomcat 虚拟主机。
例如现在新增两个域名 www.kgc.com 和 www.benet.com, 希望通过这两个域名访问到不同的项目内容。
2.6.1 创建kgc 和 benet 项目目录和文件
mdkir /usr/local/tomcat/webapps/kgc
mdkir /usr/local/tomcat/webapps/benet
ehco "This is kgc page\!" > /usr/local/tomcat/webapps/kgc/index.jsp
ehco "This is benet page\!" > /usr/local/tomcat/webapps/benet/index.jsp
2.6.2 修改tomcat主配置文件server.xml
2.6.3 重启tomcat服务2.6.4 设置域名解析
2.6.5 测试
浏览器输入http://www.my.com:8080和http://www.qyd.com:8080
三. Tomcat优化
3.1 Tomcat配置文件参数优化
【redirectPort】如果某连接器支持的协议是HTTP,当接收客户端发来的HTTPS请求时,则转发至此属性定义的端口。
【maxThreads】Tomcat使用线程来处理接收的每个请求,这个值表示Tomcat可创建的最大的线程数,即支持的最大并发连接数,默认值是 200。
【minSpareThreads】最小空闲线程数,Tomcat 启动时的初始化的线程数,表示即使没有人使用也开这么多空线程等待,默认值是 10。
【maxSpareThreads】最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值是-1(无限制)。一般不需要指定。
【URIEncoding】指定 Tomcat 容器的 URL 编码格式,语言编码格式这块倒不如其它 Web服务器软件配置方便,需要分别指定。
【connnectionTimeout】网络连接超时,单位:毫秒,设置为 0 表示永不超时,这样设置有隐患的。通常默认 20000 毫秒就可以。
【enableLookups】是否反查域名,以返回远程主机的主机名,取值为:true 或 false,如果设置为 false,则直接返回 IP 地址,为了提高处理能力,应设置为 false。
【disableUploadTimeout】上传时是否使用超时机制。应设置为 true。
【connectionUploadTimeout】上传超时时间,毕竟文件上传可能需要消耗更多的时间,这个根据你自己的业务需要自己调,以使Servlet有较长的时间来完成它的执行,需要与上一个参数一起配合使用才会生效。
【acceptCount】指定当所有可以使用的处理请求的线程数都被使用时,可传入连接请求的最大队列长度,超过这个数的请求将不予处理,默认为 100 个。
【compression】是否对响应的数据进行GZIP压缩,off:表示禁止压缩;on:表示允许压缩(文本将被压缩)、force:表示所有情况下都进行压缩,默认值为 off,压缩数据后可以有效的减少页面的大小,一般可以减小 1/3 左右,节省带宽。
【compressionMinSize】表示压缩响应的最小值,只有当响应报文大小大于这个值的时候才会对报文进行压缩,如果开启了压缩功能,默认值就是 2048。
【compressableMimeType】压缩类型,指定对哪些类型的文件进行数据压缩。
【noCompressionUserAgents="gozilla, traviata"】对于以下的浏览器,不启用压缩