文章目录
一、Tomcat 介绍
三大基础软件:操作系统、数据库、中间件。
中间件位于客户机/ 服务器的操作系统之上,管理计算机资源和网络通讯。是连接两个独立应用程序或独立系统的软件。相连接的系统,即使它们具有不同的接口,但通过中间件相互之间仍能交换信息。执行中间件的一个关键途径是信息传递。通过中间件,应用程序可以工作于多平台或OS环境。
1.主机就是普通的PC或者是服务器
2.数据库通俗点说就是存储数据的地方,比较常见的有Oracle,SqlServer,DB2等
3.中间件就是运行项目的服务器,常见的有tomcat,weblogic,websphere等 web
4.存储 ,存储是比较抽象的概念,不是具体的硬件
比如一个web项目,首先将数据库以及中间件安装在服务器上,首先启动中间件,让项目开始运行,当浏览器访问项目的时候,将数据存储在数据库中.
Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun和其他一些公司及个人共同开发而成。
Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP程序的首选。
Tomcat和Nginx、Apache(httpd)、lighttpd等Web服务器一样,具有处理HTML页面的功能,另外它还是一个Servlet和JSP容器,独立的Servlet容器是Tomcat的默认模式。不过,Tomcat处理静态HTML的能力不如Nginx/Apache服务器。
1、Tomcat与Apache服务器的关系?
1.Apache是web服务器,Tomcat是应用(java)服务器,它只是一个servlet容器,是Apache的扩展。
2.Apache和Tomcat都可以做为独立的web服务器来运行,但是Apache不能解释java程序(jsp,serverlet)。
3.Apache是普通服务器,本身只支持html即普通网页。不过可以通过插件支持php,还可以与Tomcat连通(单向Apache连接Tomcat,就是说通过Apache可以访问Tomcat资源。反之不然)
4.两者都是一种容器,只不过发布的东西不同:Apache是html容器,功能像IIS一样;Tomcat是jsp/servlet容器,用于发布jsp及java的,类似的有IBM的webshere、EBA的Weblogic,sun的JRun等等。
5.Apache和Tomcat是独立的,在通一台服务器上可以集成。
打个比方:Apache是一辆卡车,上面可以装一些东西如html等。但是不能装水,要装水必须要有容器(桶),Tomcat就是一个桶(装像Java这样的水),而这个桶也可以不放在卡车上。
2、工作原理:
-
Server:指的就是整个 Tomcat 服 务器,包含多组服务,负责管理和 启动各个 Service,同时监听 8005 端口发过来的 shutdown 命令,用 于关闭整个容器 ;
-
Service:Tomcat 封装的、对外提 供完整的、基于组件的 web 服务, 包含 Connectors、Container 两个 核心组件,以及多个功能组件,各 个 Service 之间是独立的,但是共享 同一 JVM 的资源 ;
-
Connector:Tomcat 与外部世界的连接器,监听固定端口接收外部请求,传递给 Container,并 将 Container 处理的结果返回给外部;
-
Container:Catalina,Servlet 容器,内部有多层容器组成,用于管理 Servlet 生命周期,调用 servlet 相关方法。
-
Loader:封装了 Java ClassLoader,用于 Container 加载类文件;
Realm:Tomcat 中为 web 应用程序提供访问认证和角色管理的机制; -
JMX:Java SE 中定义技术规范,是一个为应用程序、设备、系统等植入管理功能的框架,通过 JMX 可以远程监控 Tomcat 的运行状态;
-
Jasper:Tomcat 的 Jsp 解析引擎,用于将 Jsp 转换成 Java 文件,并编译成 class 文件。
-
Session:负责管理和创建 session,以及 Session 的持久化(可自定义),支持 session 的集群。
-
Pipeline:在容器中充当管道的作用,管道中可以设置各种 valve(阀门),请求和响应在经由管 道中各个阀门处理,提供了一种灵活可配置的处理请求和响应的机制。
-
Naming:命名服务,JNDI, Java 命名和目录接口,是一组在 Java 应用中访问命名和目录服务的 API。命名服务将名称和对象联系起来,使得我们可以用名称访问对象,目录服务也是一种命名 服务,对象不但有名称,还有属性。Tomcat 中可以使用 JNDI 定义数据源、配置信息,用于开发 与部署的分离。
一个Tomcat中只有一个Server,一个Server可以包含多个Service,一个Service只有一个Container,但是可以有多个Connectors,这是因为一个服务可以有多个连接,如同时提供Http和Https链接,也可以提供向相同协议不同端口的连接
Container组成
Engine:引擎,用来管理多个站点,一个Service最多只能有一个Engine;
Host: 代表一个站点,也可以叫虚拟主机,通过配置Host就可以添加站点;
Context: 代表一个应用程序,对应着平时开发的一套程序,或者一个WEB-INF目录以及下面的web.xml文件;
Wrapper:最底层的容器,是对 Servlet 的封装,负责 Servlet 实例的创建、执行和销毁。 每一Wrapper封装着一个Servlet;
多个 Connector 和一个 Container 就形成了一个 Service,有了 Service 就可以对外提供服务了,但是 Service 还要一个生存的环境,整个 Tomcat 的生命周期由 Server 控制
Server标签设置的端口号为8005,shutdown=”SHUTDOWN” ,表示在8005端口监听“SHUTDOWN”命令,如果接收到了就会关闭Tomcat。一个Server有一个Service,当然还可以进行配置,一个Service有多个,Service左边的内容都属于Container的,Service下边是Connector。
- Tomcat中只有一个Server,一个Server可以有多个Service,一个Service可以有多个Connector和一个Container;
- Server掌管着整个Tomcat的生死大权;
- Service 是对外提供服务的;
- Connector用于接受请求并将请求封装成Request和Response来具体处理;
- Container用于封装和管理Servlet,以及具体处理request请求;
二、Tomcat 安装
目前Tomcat最新版本为10.0。Java容器还有resin、weblogic等。
Tomcat官网:https://tomcat.apache.org/
1、关闭selinux、防火墙
systemctl stop firewalld.service
systemctl disable firewalld.service
firewall-cmd --state
sed -i '/^SELINUX=.*/c SELINUX=disabled' /etc/selinux/config
sed -i 's/^SELINUXTYPE=.*/SELINUXTYPE=disabled/g' /etc/selinux/config
grep --color=auto '^SELINUX' /etc/selinux/config
setenforce 0
2、安装JDK
也可自行安装其他版本两种方式
- yum安装
yum install java-1.8.0-openjdk -y
jdk版本:java version "1.8.0_262"
# 解压 & 安装
$ tar -xvf jdk-8u301-linux-x64.tar.gz
$ mv jdk1.8.0_301/ /usr/local/
$ ln -s jdk1.8.0_301 jdk1.8
# 设置环境变量
$ vim /etc/profile
export JAVA_HOME=/usr/local/jdk1.8
export CLASSPATH=.:${JAVA_HOME}/jre/lib/rt.jar:${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar
export PATH=$PATH:${JAVA_HOME}/bin
$ 生效变量
$ source /etc/profile
3、安装Tomcat
tomcat下载地址:https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/
cd /usr/local/src/
wget https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-8/v8.5.70/bin/apache-tomcat-8.5.70.tar.gz
tar -zxvf apache-tomcat-8.5.70.tar.gz -C /usr/local/
mv /usr/local/apache-tomcat-8.5.70 /usr/local/tomcat_1
检查tomcat是否安装成功
[root@controller1 src]# /usr/local/tomcat_1/bin/version.sh
Using CATALINA_BASE: /usr/local/tomcat_1
Using CATALINA_HOME: /usr/local/tomcat_1
Using CATALINA_TMPDIR: /usr/local/tomcat_1/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat_1/bin/bootstrap.jar:/usr/local/tomcat_1/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Server version: Apache Tomcat/8.5.70
Server built: Aug 9 2021 16:17:14 UTC
Server number: 8.5.70.0
OS Name: Linux
OS Version: 3.10.0-1160.el7.x86_64
Architecture: amd64
JVM Version: 1.8.0_302-b08
JVM Vendor: Red Hat, Inc.
启动/停止tomcat
[root@controller1 src]# /usr/local/tomcat_1/bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat_1
Using CATALINA_HOME: /usr/local/tomcat_1
Using CATALINA_TMPDIR: /usr/local/tomcat_1/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat_1/bin/bootstrap.jar:/usr/local/tomcat_1/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.
[root@controller1 src]# ss -tpln | grep java
LISTEN 0 1 [::ffff:127.0.0.1]:8005 [::]:* users:(("java",pid=12085,fd=66))
LISTEN 0 100 [::]:8080 [::]:* users:(("java",pid=12085,fd=54))
[root@controller1 src]# /usr/local/tomcat_1/bin/shutdown.sh
Using CATALINA_BASE: /usr/local/tomcat_1
Using CATALINA_HOME: /usr/local/tomcat_1
Using CATALINA_TMPDIR: /usr/local/tomcat_1/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat_1/bin/bootstrap.jar:/usr/local/tomcat_1/bin/tomcat-juli.jar
Using CATALINA_OPTS:
4、优化
1、解决Tomcat启动慢的方法
Tocmat的Session ID是通过SHA1算法计算得到的,计算Session ID的时候必须有一个密钥。为了提高安全性Tomcat在启动的时候会通过随机数生成一个密钥。Tomcat启动慢主要原因是生成随机数的时候卡住了,导致tomcat启动不了。
是否有足够的熵来用于产生随机数,可以通过如下命令来查看
cat /proc/sys/kernel/random/entropy_avail
3001
为了加速/dev/random提供随机数的速度,你可以通过操作设备的外设,让其产生大量的中断,网络传输数据,按键,移动鼠标,在命令行敲几个不同的命令,俗称聚气。
yum install rng-tools -y # 安装rngd服务(熵服务,增大熵池)
systemctl start rngd # 启动服务
2、Tomcat目录介绍
[root@controller1 tomcat_1]# tree -L 1
├── bin #存放tomcat管理脚本
├── conf # tomcat 配置文件存放目录
├── lib # web应用调用的jar包存放路径
├── LICENSE
├── logs # tomcat 日志存放目录,catalina.out 为主要输出日志
├── NOTICE
├── RELEASE-NOTES
├── RUNNING.txt
├── temp # 存放临时文件
├── webapps # web程序存放目录
└── work # 存放编译产生的.java 与 .class文件
7 directories, 4 files
webapps目录介绍
[root@controller1 webapps]# tree -L 1
├── docs # tomcat 帮助文档
├── examples # web应用实例
├── host-manager # 主机管理
├── manager # 管理
└── ROOT # 默认站点根目录
5 directories, 0 files
Tomcat配置文件目录介绍(conf)
[root@controller1 conf]# tree -L 1
├── Catalina
├── catalina.policy
├── catalina.properties
├── context.xml
├── jaspic-providers.xml
├── jaspic-providers.xsd
├── logging.properties
├── server.xml # tomcat 主配置文件
├── tomcat-users.xml # tomcat 管理用户配置文件
├── tomcat-users.xsd
└── web.xml
浏览器进行访问
http://ip:8080
3、Tomcat管理功能使用
Tomcat管理功能用于对Tomcat自身以及部署在Tomcat上的应用进行管理的web应用。在默认情况下是处于禁用状态的。如果需要开启这个功能,就需要配置管理用户,即配置tomcat-users.xml 文件。
# vi /usr/local/tomcat_1/conftomcat-users.xml
在倒数第二行加入如下内容并保存:
<role rolename="admin-gui"/>
<role rolename="admin-script"/>
<user username="tomcat" password="tomcat" roles="admin-script,admin-gui"/>
这里的amdin-gui和admin-script是两个Tomcat内置的角色,host-manager功能需要这两个角色的支持,其中admin-gui用来控制页面访问权限,admin-script用于控制以简单的文本的形式进行访问host-manager。
重启tomcat
systemctl restart tomcat
此时再浏览器里输入http://ip:8080/host-manager/ 就可以访问主机界面了,但此时还有点问题,会提示403,这是因为Tomcat还有一个安全的配置,默认不允许这个客户端IP访问host-manager页面,解决的办法是修改配置文件:
# vim /usr/local/tomcat_1/webapps/host-manager/META-INF/context.xml
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1|192\.168\.1.*" />
systemctl restart tomcat
# curl 127.0.0.1:8080/host-manager/html //虚拟机测试访问
重启tomcat再次登陆
http://ip:8080/host-manager/