目录
一.tomcat介绍
Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,Tomcat具有处理HTML页面的功能,它还是一个Servlet和JSP容器 起始于SUN公司的一个Servlet的参考实现项目Java Web Senver,开发者是James Duncan Davidson,在19年,将项目贡献给了apache软件基金会(ASF),和ASF现有的项目JServ合并,并开源成为顶级项目
主要组件
-
Catalina:这是Tomcat的Servlet容器核心,实现了Servlet和JSP的规范。Catalina负责管理Servlet生命周期,包括加载、初始化、服务请求和销毁。
-
Coyote:这是Tomcat的连接器组件,支持HTTP 1.1协议,负责解析HTTP请求并将其传递给Catalina进行处理。
-
Jasper:这是Tomcat的JSP引擎,将JSP文件编译成Servlet代码,从而在服务器端执行。
-
Cluster:用于支持Tomcat集群的组件,提供会话复制和负载均衡功能,以实现高可用性和扩展性。
-
Valves 和 Filters:用于请求和响应的预处理和后处理,例如日志记录、身份验证和访问控制等。
主要特点
- 轻量级:相比于完整的Java EE应用服务器(如WildFly或GlassFish),Tomcat更加轻量级,适合中小型应用程序以及开发和测试环境。
- 高性能:得益于高效的Servlet引擎和优化的连接器,Tomcat在处理HTTP请求时具有较好的性能。
- 灵活性和可扩展性:通过配置文件(如server.xml和web.xml)和插件机制,可以根据需要对Tomcat进行高度自定义和扩展。
- 跨平台:作为一个纯Java应用程序,Tomcat可以在支持Java的任何操作系统上运行,包括Windows、Linux和macOS等。
使用场景
- Web应用开发和测试:开发人员经常使用Tomcat作为本地开发和测试环境,因其配置简单且快速启动。
- 中小型Web应用部署:由于其轻量级和高效特性,很多中小型企业选择Tomcat作为生产环境的Web服务器。
- 微服务架构:在微服务架构中,Tomcat常被用作各个微服务的独立运行容器。
管理和配置
- 配置文件:Tomcat的主要配置文件包括
server.xml
、web.xml
和context.xml
,分别用于全局服务器配置、Web应用配置和每个应用的上下文配置。 - 管理界面:Tomcat提供了一个基于Web的管理界面(Manager App),允许管理员部署、启动、停止和监控Web应用程序。
- 日志记录:Tomcat使用Apache Commons Logging框架来记录日志信息,默认情况下,日志存储在
logs
目录中
二.tomcat安装
1.关闭防火墙
[root@localhost data]# systemctl stop firewalld
[root@localhost data]# setenforce 0
2.将下载好的tomcat ,rpm包拖入/data目录下
[root@localhost data]# ls
apache-tomcat-9.0.16.tar.gz HeapOom2.java jdk-8u201-linux-x64.rpm
3.使用rpm 命令下载tomcat,并查找安装路径
[root@localhost data]# rpm -ivh jdk-8u201-linux-x64.rpm
警告:jdk-8u201-linux-x64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID ec551f03: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:jdk1.8-2000:1.8.0_201-fcs ################################# [100%]
Unpacking JAR files...
tools.jar...
plugin.jar...
javaws.jar...
deploy.jar...
rt.jar...
jsse.jar...
charsets.jar...
localedata.jar...
[root@localhost data]# rpm -ql jdk1.8 | tail -n 1
/usr/java/jdk1.8.0_201-amd64/src.zip
4.使用java -version 命令查看版本设置环境变量
5.进入 vim /etc/profile 查找到子配置文件位置
/etc/profile.d/*.sh //子配置文件路径
6.编写java环境变量
vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/java/jdk1.8.0_201-amd64
export JRE_HOME=$JAVA_HOME/jre
export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$PATH
7.使用supervisor启动
解压包 apache-tomcat-9.0.16.tar.gz
[root@localhost data]# tar zxvf apache-tomcat-9.0.16.tar.gz
8.将源码包目录拷贝至/usr/local/下并重命名为tomcat #简化路径,方便管理,并测试开关闭tomcat服务
[root@localhost data]# cp -r apache-tomcat-9.0.16 /usr/local/tomcat
[root@localhost data]# cd /usr/local/tomcat/
[root@localhost tomcat]# /usr/local/tomcat/bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr/java/jdk1.8.0_201-amd64/jre
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
[root@localhost tomcat]# /usr/local/tomcat/bin/shutdown.sh
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr/java/jdk1.8.0_201-amd64/jre
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
9.新建用户tomcat并修改tomcat属主和属组
[root@localhost tomcat]# useradd -s /sbin/nologin tomcat
[root@localhost local]# chown tomcat:tomcat tomcat/ -R
10.修改配置文件
[root@localhost local]# cat > /usr/lib/systemd/system/tomcat.service <<EOF
> [Unit]
> Description=Tomcat
> After=syslog.target network.target
>
> [Service]
> Type=forking
> ExecStart=/usr/local/tomcat/bin/startup.sh
> ExecStop=/usr/local/tomcat/bin/shutdown.sh
> RestartSec=3
> PrivateTmp=true
> User=tomcat
> Group=tomcat
> [Install]
> WantedBy=multi-user.target
>
> EOF
11.启动服务查看端口号情况
[root@localhost local]# systemctl daemon-reload
[root@localhost local]# systemctl start tomcat
[root@localhost local]# ss -ntap |grep 8080
访问192.168.240.13:8080
三.配置文件介绍及核心组件
1.配置文件
目录名字 | 功能 |
---|---|
bin | 存放启动和关闭 Tomcat 的脚本文件,比较常用的是 catalina.sh、startup.sh、shutdown.sh 三个文件 |
conf | 存放 Tomcat 服务器的各种配置文件,比较常用的是 server.xml、context.xml、tomcat-users.xml、web.xml 四个文件。 |
lib | 存放 Tomcat 服务器的 jar 包,一般不作任何改动,除非连接第三方服务,比如 redis,那就需要添加相对应的 jar 包 |
logs | 存放 Tomcat 日志 catalina.out |
temp | 存放 Tomcat 运行时产生的文件 |
webapps | 存放项目资源的目录 |
work | Tomcat 工作目录,一般清除 Tomcat 缓存的时候会使用到(升级版本时注意要删除里面的缓存) |
2.conf子目录
文件名 | 说明 |
---|---|
server.xml | 主配置文件 全局生效 |
web.xml | 每个webapp只有“部署"后才能被访问,它的部署方式通常由web.xml进行定义,其存放位置为WEB-INF/目录中;此文件为所有的webapps提供默认部署相关的配置,每个web应用也可以使用专用配置文件,来覆盖全局文件 |
context.xml | 用于定义所有web应用均需加载的Context配置,此文件为所有的webapps提供默认配置,每个web应用也可以使用自已专用的配置,它通常由专用的配置文件context.xml来定义,其存放位置为WEB-INF/目录中,覆盖全局的文件 |
tomcat-users.xml | 用户认证的账号和密码文件 |
catalina.policy | 当使用security选项启动omcat时,用于为tomcat设置安全策略 |
catalina.properties | Tomcat环境变量的配置,用于设定类加载器路径,以及一些与JVM调优相关参数 |
logging.properties | Tomcat日志系统相关的配置,可以修改日志级别和日志路径等 |
注意配置文件对于大小写敏感 |
3.日志文件
参考文档: Logging - Apache Tomcat - Apache Software Foundation
日志格式: Apache Tomcat 9 Configuration Reference (9.0.89) - The Valve Component
4.组件
名称 | 说明 |
---|---|
server | 服务器,Tomcat运行的进程实例,一个Server中可以有多个service,但通常就一个 |
service | 服务,用来组织Engine(引擎)和Connector(连接器,端口)的对应关系,一个service中只有一个Engine |
connector | 连接器,负责客户端的HTTP、HTTPS、AJP等协议连接。一个Connector只属于某一个Engine |
Engine | 即引擎,用来响应并处理用户请求。一个Engine上可以绑定多个Connector |
Host | 即虚拟主机,可以实现多虚拟主机,例如使用不同的主机头区分 |
Context | 应用的上下文,配置特定url路径映射和目录的映射关系: url => directory |
5.核心组件
-
Tomcat启动一个Server进程。可以启动多个Server,即tomcat的多实例, 但一般只启动一个
-
创建一个Service提供服务。可以创建多个Service,但一般也只创建一个
-
每个Service中,是Engine和其连接器Connector的关联配置
-
-
可以为这个Service提供多个连接器Connector,这些Connector使用了不同的协议,绑定了不同的端口。其作用就是处理来自客户端的不同的连接请求或响应
-
Service 内部还定义了Engine,引擎才是真正的处理请求的入口,其内部定义多个虚拟主机Host
-
Engine对请求头做了分析,将请求发送给相应的虚拟主机
-
如果没有匹配,数据就发往Engine上的defaultHost缺省虚拟主机
-
Engine上的缺省虚拟主机可以修改
-
-
Host 定义虚拟主机,虚拟主机有name名称,通过名称匹配
-
Context 定义应用程序单独的路径映射和配置
6.tomcat端口
在conf/server.xml 有以下内容
<?xml version="1.0" encoding="UTF-8"?>
<Server port="8005" shutdown="SHUTDOWN">
<Service name="Catalina">
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
<Engine name="Catalina" defaultHost="localhost">
<Host name="localhost" appBase="webapps"
unpackWARs="true" autoDeploy="true">
</Host>
</Engine>
</Service>
</Server>
8080: 默认接收 http 请求的端口
8005: 安全端口,可以关闭tomcat
8005是Tomcat的管理端口,默认监听在127.0.0.1上。无需验证就可发送SHUTDOWN (大小写敏感)这个字符串,tomcat接收到后就会关闭此Server。
8009: apache 和 tomcat 联动 AJP 协议
四.tomcat虚拟主机
1.为什么要出现虚拟主机?
可能有时候公司会有多个项目需要运行,那么肯定不可能是一台服务器上运行多个 Tomcat 服务,这样会消耗太多的系统资源。此时,就需要使用到 Tomcat 虚拟主机
2.创建虚拟主机前,必须先创建相关目录,否则创建虚拟机不成功
[root@localhost ~]# mkdir /data/web{1,2,3}/ROOT/ -pv
mkdir: 已创建目录 "/data/web1"
mkdir: 已创建目录 "/data/web1/ROOT/"
mkdir: 已创建目录 "/data/web2"
mkdir: 已创建目录 "/data/web2/ROOT/"
mkdir: 已创建目录 "/data/web3"
mkdir: 已创建目录 "/data/web3/ROOT/" //创建相关目录
[root@localhost ~]# echo web1 > /data/web1/ROOT/index.html
[root@localhost ~]# echo web2 > /data/web2/ROOT/index.html
[root@localhost ~]# echo web3 > /data/web3/ROOT/index.html
//给web 1 2 3建立网页
[root@localhost ~]# chown -R tomcat.tomcat /data/ //修改属主和属组
3.编辑配置文件 /usr/local/tomcat/conf/server.xml
找到 host 主机项 ,注意 根目录中 一定要有 ROOT 这是默认 的主目录
4.重启tomcat服务,在另一台主机hosts文件中添加虚拟主机的ip与域名
并使用curl命令测试
五.tomcat 优化
1. 配置JVM
- 内存设置:调整JVM的内存参数,例如
-Xms
和-Xmx
,设定初始和最大堆内存大小。例如:
-Xms2048m -Xmx2048m
- 垃圾回收器:选择适合你的应用的垃圾回收器(GC),例如 G1 GC 在大多数情况下表现较好:
-XX:+UseG1GC
2. 优化Tomcat连接器
- 线程池:调整连接器线程池的大小以处理更多并发请求。在
server.xml
文件中配置maxThreads
和minSpareThreads
:<Connector port="8080" protocol="HTTP/1.1" maxThreads="200" minSpareThreads="25" connectionTimeout="20000" redirectPort="8443" />
- Keep-Alive 设置:适当配置Keep-Alive超时和最大连接数:
<Connector port="8080" protocol="HTTP/1.1"
maxKeepAliveRequests="100"
keepAliveTimeout="5000" />
3. 调整Tomcat缓存
- HTTP缓存:启用和配置HTTP缓存,以减少对静态资源的重复请求:
<Resources cachingAllowed="true" cacheMaxSize="100000" />
4. 优化数据库连接池
- 连接池大小:调整数据库连接池大小以满足应用需求,避免连接过少导致的性能瓶颈:
<Resource name="jdbc/mydb" auth="Container" type="javax.sql.DataSource" maxTotal="100" maxIdle="30" minIdle="10" maxWaitMillis="10000" ... />
六.tomcat 和 nginx 动静分离
前期准备
[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# setenforce 0
1.在192.168.240.10上编译安装nginx
步骤详情见Nginx 搭建 lnmp-CSDN博客
在10主机进入配置文件,编辑配置文件
做反向代理负载均衡
vim /usr/local/nginx/conf/nginx.conf
2.在192.168.240.11,主机上安装nginx
进入主配置文件,添加动静分离并重新启动nginx服务
3.在192.168.240.12上安装nginx服务
编辑主配置文件,添加动静分离并重新启动nginx服务
4.在192.168.240.13上安装tomcat服务
设置jsp文件并重新启动tomcat服务
5.在192.168.240.14上安装tomcat服务
设置jsp文件并重新启动tomcat服务
6.在客户机上测试