Tomcat部署及优化

114 阅读8分钟

什么是Tomcat

Tomcat 是 Java 语言开发的 Tomcat 服务器是一个免费的开发源代码的 Web 应用服务器, 是 Apache 软件基金会的 Jakarta项目中的一个核心项目,由Apache Sun 和其他一些公司及个人共同开发而成的

Tomcat 属于轻量级应用服务器,在中小型系统和并发访问用户并不是很多的场合下被普遍使用,是开发和调试JSP程序的首先,一般来说 Tomcat 虽然和 Apache 或者Ngingx 这些 Web 服务器一样, 具有处理HTML 的功能,然而由于处理静态HTML 的能力远不及 Apache 或者 Nginx , 所以 Tomcat 通常是作为一个Servlet 和JSP 容器 ,单独运行在后端 

Tomcat的作用是什么

Web 网站应用服务器 (处理静态html页面)
servlet/JSP 容器 承载动态页面的 (处理JAVA开发的.jsp动态网页文件)

nginx + tomcat /php 等组合搭配
静态页面  动态页面

如何区分nginx和tomcat呢

nginx可以通过 location ~ 正则匹配访问路径后缀确定要访问的文件类型
fastcgi_pass -> php-fpm -> php
prexy_pass -> tomcat (代理转发)

Tomcat的组建构成

Tomcat 由一系列组件构成,其中核心的组件有三个:
1.Web容器:完成Web服务器的功能
2.Servlet容器:名字为catalina,用于处理Servlet代码
3.JSP容器: 将JSP动态页面翻译成Servlet代码

因此 Tomcat 是 Web 应用服务器,也是应该 Servlet/JSP 容器,负责处理jsp动态请求,把请求传送给Servlet,并将Servlet的响应传送给客户。

什么是servlet

servlet 是 java servlet 的简称, 可以理解成是一个服务连接器,是用于Java 编写的服务器端程序,具有独立于平台和协议的特性,简单的理解:servlet精神一个中间件,包含了接口和方法,将客户端和数据库连接,从而实现动态网页的创建

什么是JSP

JSP 全程 Java Server Pages,是一种动态网页开发技术,它使用JSP标签 在HTML网页输入Java代码,标签通常以<%开头,以%>结束
JSP 是一种Java servlet,主要用于实现Java web 应用程序地用户界面部分
JSP 通过网页表单获取用户输入数据,访问数据库及其它数据源,然后动态的创建页面。

Tomcat 功能组件结构:

Tomcat 的核心功能有两个,分别是负责接收和反馈外部请求的连接器 Connector,和负责处理请求的容器Container。其中连接器和容器相辅相成
Connector:负责对外接收和响应请求,它是Tomcat与外界的交通枢纽,监听端口接收外界请求,并将请求处理后传递给容器做业务处理,最后将容器处理后的结果响应给外界
Container:负责对内处理业务逻辑,其内部由 English、Host、Conter和rapper 四个容器组成,用于管理和调用 Servlet 相关逻辑
Servlet:对外提供的Web服务,主要包含 Connector 和 Container 两个核心组件,以及其他功能组件,Tomcat可以管理多个Service,且各service相互独立

Tomcat的结构分析:

每个Service会包含一个 Container 容器。在 Container 内包含了4个子容器;
4个子容器的作用分别是:
(1)Engine:引擎,用来管理多个虚拟主机,一个Service 最多可以有一个Engine;
(2)Host:代表一个虚拟主机,也可以叫站点,通过配置Host就可以添加站点;
(3)Context:代表一个Web应用,包含多个Servlet封装器;
(4)Wrapper:封装器,容器得最底层,每一个 Wrapper 封装着一个Servlet,负责对象实例得创建、执行和销毁功能
Engine、Host、Context和Wapper 这四个容器属于父子关系
容器 由一个引擎可以管理多个虚拟主机,每个虚拟主机可以管理多个Web应用,每个Web 应用会有多个Servlet封装器

Tomcat请求过程

1.用户在浏览器中输入网址,请求被发送到本机端口8080,被在那里监听 Connector 获得
2.Connctor 把该请求交给它所在地 Service 的 Engine (Container)来处理,并等待 Engine 地响应;
3.请求在 Engine、Host、Context 和 Wraper 这四个容器之间层层调用,最后在 Servlet 中执行对应地业务逻辑,数据存储等。
4.执行完之后地请求响应在 Context、Host、Engine 容器之间层次返回,最后通过 Connector 返回给客户端 

Tomcat四大端口

8080 http的连接端口   接收http连接请求
8443 https的连接端口
8005 服务关闭端口
8009 AJP端口,Apache做代理服务的能通过AJP协议访问tomcat的8009端口

Tomcat服务部署安装

1.关闭防火墙,将安装 Tomcat 所需软件包传到/opt目录下

image.png

2.安装JDK

image.png

image.png

image.png

image.png

image.png 4.安装启动Tomcat

image.png

image.png

image.png

image.png

image.png

image.png 5.优化tomcat启动速度

image.png

image.png

主要目录
●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虚拟主机配置

1.创建 hhh 和 ggg 项目目录和文件

image.png 2.修改 Tomcat 主配置文件 server.xml

vim /usr/local/tomcat/conf/server.xml image.png

image.png

image.png

Tomcat的优化

Tomcat默认安装下的缺省配置并不适合生产环境,它可能会频繁出现假死现象需要重启,只有通过不断压测优化才能让它最高效率稳定的运行。优化主要包括三方面,分别为操作系统优化(内核参数优化),Tomcat配置文件参数优化,Java虚拟机(JVM)调优。

Tomcat 配置文件参数优化

常用的优化相关参数如下:
【redirectPort】如果某连接器支持的协议是HTTP,当接收客户端发来的HTTPS请求时,则转发至此属性定义的 8443 端口。

【maxThreads】Tomcat使用线程来处理接收的每个请求,这个值表示Tomcat可创建的最大的线程数,即支持的最大并发连接数,默认值是 200。

【minSpareThreads】最小空闲线程数,Tomcat 启动时的初始化的线程数,表示即使没有人使用也开这么多空线程等待,默认值是 10。

【maxSpareThreads】最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值是-1(无限制)。一般不需要指定。

【processorCache】进程缓冲器,可以提升并发请求。默认值是200,如果不做限制的话可以设置为-1,一般采用maxThreads的值或者-1。

【URIEncoding】指定 Tomcat 容器的 URL 编码格式,网站一般采用UTF-8作为默认编码。

【connnectionTimeout】网络连接超时,单位:毫秒,设置为 0 表示永不超时,这样设置有隐患的。通常默认 20000 毫秒就可以。

【enableLookups】是否反查域名,以返回远程主机的主机名,取值为:truefalse,如果设置为 false,则直接返回 IP 地址,为了提高处理能力,应设置为 false。

【disableUploadTimeout】上传时是否使用超时机制。应设置为 true。

【connectionUploadTimeout】上传超时时间,毕竟文件上传可能需要消耗更多的时间,这个根据你自己的业务需要自己调,以使Servlet有较长的时间来完成它的执行,需要与上一个参数一起配合使用才会生效。

【acceptCount】指定当所有可以使用的处理请求的线程数都被使用时,可传入连接请求的最大队列长度,超过这个数的请求将不予处理,默认为 100 个。

【maxKeepAliveRequests】指定一个长连接的最大请求数。默认长连接是打开的,设置为1时,代表关闭长连接;为-1时,代表请求数无限制

【compression】是否对响应的数据进行GZIP压缩,off:表示禁止压缩;on:表示允许压缩(文本将被压缩)、force:表示所有情况下都进行压缩,默认值为 off,压缩数据后可以有效的减少页面的大小,一般可以减小 1/3 左右,节省带宽。

【compressionMinSize】表示压缩响应的最小值,只有当响应报文大小大于这个值的时候才会对报文进行压缩,如果开启了压缩功能,默认值就是 2048。

【compressableMimeType】压缩类型,指定对哪些类型的文件进行数据压缩。

【noCompressionUserAgents="gozilla, traviata"】对于以下的浏览器,不启用压缩
#如果已经进行了动静分离处理,静态页面和图片等数据就不需做 Tomcat 处理,也就不要在 Tomcat 中配置压缩了。

以上是一些常用的配置参数,还有好多其它的参数设置,还可以继续深入的优化,HTTP Connector 与 AJP Connector 的参数属性值,可以参考官方文档的详细说明进行学习。

vim /usr/local/tomcat/conf/server.xml