这里写目录标题
一、Tomcat介绍
- 是免费的、开放源代码的Web应用服务器
- Apache软件基金会(Apache Software Foundation),Jakarta项目中的一个核心项目
- 由 Apache、Sun和一些公司及个人共同开发而成
- 深受Java爱好者的喜爱,并得到部分软件开发商的认可
- 目前比较流行的Web应用服务器
1.1 Tomcat 的核心组件
- web容器:web服务器
- Servlet容器:名为catalina,处理Servlet代码
- JSP 容器: 将 JSP动态网页,翻译成Servlet网页
1.2 Tomcat的处理请求过程
- 1.用户在浏览器中输入网址localhost:8080/test/index.jsp,请求被发送到本机端口8080,被在那里监听的Coyote HTTP/1.1 Connector获得;
- 2.Connector把该请求交给它所在的Service的Engine(Container)来处理,并等待Engine的回应;
- 3.Engine获得请求localhost/test/index.jsp,匹配所有的虚拟主机Host;
- 4.Engine匹配到名为localhost的Host(即使匹配不到也把请求交给该Host处理,因为该Host被定义为该Engine的默认主机),名为localhost的Host获得请求/test/index.jsp,匹配它所拥有的所有Context。Host匹配到路径为/test的Context(如果匹配不到就把该请求交给路径名为“ ”的Context去处理);
- 5.path=“/test”的Context获得请求/index.jsp,在它的mapping table中寻找出对应的Servlet。Context匹配到URL Pattern为*.jsp的Servlet,对应于JspServlet类;
- 6.构造HttpServletRequest对象和HttpServletResponse对象,作为参数调用JspServlet的doGet()或doPost(),执行业务逻辑、数据存储等;
- 7.Context把执行完之后的HttpServletResponse对象返回给Host;
- 8.Host把HttpServletResponse对象返回给Engine;
- 9.Engine把HttpServletResponse对象返回Connector;
- 10.Connector把HttpServletResponse对象返回给客户Browser
1.2.1 处理过程名词解析
-
connector:连接器
一个Connector组件将在某个指定的端口上侦听客户请求,接收浏览器发过来的tcp连接请求,创建一个Request和一个Response对象分别用于和其你去端交换数据,然后会产生一个线程来处理这个请求并把产生的Request和Response对象传给Engine,从Engine中获得响应并返回给客户端。 Tomcat有两个经典的Connector,一个直接侦听来自浏览器的HTTP请求,另外一个侦听来自其他的WebServer的请求。Cotote HTTP/1.1 Connector在端口8080处侦听来自客户浏览器的HTTP请求,Coyote JK2 Connector在端口8009处侦听其他WebServer的Servlet/JSP请求。 Connector 最重要的功能就是接收连接请求然后分配线程让 Container来处理这个请求,所以这必然是多线程的,多线程的处理是 Connector 设计的核心。 -
container:
Container是容器的父接口,该容器的设计用的是典型的责任链的设计模式,它由四个自容器组件构成,分别是Engine、Host、Context、Wrapper。这四个组件是负责关系,存在包含关系。通常一个Servlet class对应一个Wrapper,如果有多个Servlet则定义多个Wrapper,如果有多个Wrapper就要定义一个更高的Container,如Context。 Context定义在父容器 Host 中,其中Host 不是必须的,但是要运行 war 程序,就必须要 Host,因为 war 中必有 web.xml 文件,这个文件的解析就需要 Host 了,如果要有多个 Host 就要定义一个 top 容器 Engine 了。而 Engine 没有父容器了,一个 Engine 代表一个完整的 Servlet 引擎。 -
engine:引擎
-
Engine 容器比较简单,它只定义了一些基本的关联关系 Host 容器
-
host:虚拟主机
Host 是 Engine 的字容器,一个 Host 在 Engine 中代表一个虚拟主机,这个虚拟主机的作用就是运行多个应用,它负责安装和展开这些应用,并且标识这个应用以便能够区分它们。它的子容器通常是 Context,它除了关联子容器外,还有就是保存一个主机应该有的信息 -
context:JSP前段页面
Context 代表 Servlet 的 Context,它具备了 Servlet 运行的基本环境,理论上只要有 Context 就能运行 Servlet 了。简单的 Tomcat 可以没有 Engine 和 Host。Context 最重要的功能就是管理它里面的 Servlet 实例,Servlet 实例在 Context 中是以 Wrapper 出现的,还有一点就是 Context 如何才能找到正确的 Servlet 来执行它呢? Tomcat5 以前是通过一个 Mapper 类来管理的,Tomcat5 以后这个功能被移到了 request 中,在前面的时序图中就可以发现获取子容器都是通过 request 来分配的 -
servlet:处理代码
1.3 JDK介绍
- JDK是Java语言的软件开发工具包
- JDK是Tomcat运行的必要环境
- 根据计算机硬件配置,选择安装包
1.4 Tomcat 文件介绍
二、安装Tomcat
2.1 准备工作
- 准备JDK 压缩包 jdk-8u201-linux-x64.rpm
- 准备 Tomcat安装包 apache-tomcat-9.0.16.tar
[root@localhost ~]# rpm -ivh jdk-8u201-linux-x64.rpm ## 安装JDK
2.2 设置JDK 环境变量
root@promote ~]# vim /etc/profile
export JAVA_HOME=/usr/java/jdk1.8.0_201-amd64
export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
export PATH=$JAVA_HOME/bin:$PATH
[root@promote ~]# source /etc/profile ## 重新加载全局环境变量文件 使刚刚的修改生效
[root@promote ~]# java -version ## 查看版本
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)
2.3 安装优化Tomcat
[root@promote ~]# tar zxvf apache-tomcat-9.0.16.tar.gz
[root@promote ~]# mv apache-tomcat-9.0.16 /usr/local/
[root@promote ~]# cd /usr/local/
[root@localhost ~]# mv apache-tomcat-9.0.16 /usr/local/
[root@localhost ~]# cd /usr/local/
[root@localhost local]# mv apache-tomcat-9.0.16/ tomcat
[root@localhost bin]# ln -s /usr/local/tomcat/bin/shutdown.sh /usr/bin/ ## 建立关闭服务脚本软连接到/usr/bin/里面
[root@localhost bin]# ln -s /usr/local/tomcat/bin/startup.sh /usr/bin/ ## 建立开启服务脚本软连接到/usr/bin/里面
2.4 开启 Tomcat
[root@localhost bin]# iptables -F
[root@localhost bin]# setenforce 0
[root@localhost 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
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
2.5 访问网站
- 访问http://192.168.233.127:8080/ ## tomcat默认端口是8080 一定要加,不加默认访问80端口 会无法访问网站
三、Tomcat优化
3.1启动速度的优化
- 第一次启动查看日志会发现 Tomcat启动很慢,默认情况下都需要几十秒,可以修改jdk参数进行优化
[root@promote bin]# vim /usr/java/jdk1.8.0_201-amd64/jre/lib/security/java.security
securerandom.source=file:/dev/urandom
3.2 其他参数的优化
<Connector port="8080" protocol="HTTP/11.1"
connectionTimeout="20000"
redirectPort="8443"
minSpareThreads="50"
enableLookups="false"
disableUploadTimeout="true"
acceptCount="300"
maxThreads="500"
processorCache="500"
URIEncoding="UTF-8"
compression="on"
compressionMinSize="2048"
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain,image/gif,image /jpg,image/png"/>
- 常见优化参数
1、maxThreads:Tomcat 使用线程来处理接收的每个请求,这个值表示 Tomcat 可创建的 最大的线程数,默认值是 200。
2、minSpareThreads:最小空闲线程数,Tomcat 启动时的初始化线程数,表示即使没有 人使用也开这么多空线程等待,默认值是
10。
3、maxSpareThreads:最大备用线程数,一旦创建的线程超过这个值,Tomcat 就会关闭 不再需要的 socket
线程。默认值是-1(无限制),一般不需要指定。
4、URIEncoding:指定 Tomcat 容器的 URL 编码格式,Tomcat 语言编码格式这块不如 其它
Web服务器软件配置方便,需要分别指定。
5、connnectionTimeout:网络连接超时,单位:毫秒,设置为 0 表示永不超时,这样设置 有隐患的。通常默认 20000
毫秒就可以。
6、enableLookups:是否反查域名,以返回远程主机的主机名,取值为:true 或 false, 如果设置为 false,则直接返回
IP 地址,为了提高处理能力,应设置为 false。
7、disableUploadTimeout:上传时是否使用超时机制。应设置为 true。
8、connectionUploadTimeout:上传超时时间,毕竟文件上传可能需要消耗更多的时间,该参数需要根据自己的业务需要自行调整,以使 Servlet 有较长的时间来完成它的执行, 需要与上一个参数一起配合使用才会生效。
9、acceptCount:指定当所有可以使用的处理请求的线程都被使用时,可传入连接请求的
最大队列长度,超过这个数的请求将不予处理,默认为 100 个。
10、compression:是否对响应的数据进行 GZIP 压缩,off 表示禁止压缩、on 表示允许压 缩(文本将被压缩)、force
表示所有情况下都进行压缩,默认值为 off。压缩数据后可 以有效的减少页面的大小,一般可以减小 1/3 左右,因而节省带宽。
11、compressionMinSize:表示压缩响应的最小值,只有当响应报文大小大于这个值的时候才会对报文进行压缩,如果开启了压缩功能,默认值就是 2048。
12、compressableMimeType:压缩类型,指定对哪些类型的文件进行数据压缩。
noCompressionUserAgents=“gozilla, traviata”:对于以下的浏览器,不启用压缩。 如果已经对代码进行了动静分离,静态页面和图片等数据就不需要 Tomcat 处理了,那 么也就不需要在 Tomcat 中配置压缩了。因为这里只有一台 Tomcat 服务器,而且压测的是 Tomcat 首页,会有图片和静态资源文件,所以这里启用压缩。
四、虚拟主机的配置
4.1 Tomcat配置文件修改
[root@localhost ~]# vim /usr/local/tomcat/conf/server.xml
<Host name="www.test01.com" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
<Context docBase="/usr/local/tomcat/webapps/test01" path="" reloadable="true"/>
</Host>
<Host name="www.test02.com" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
<Context docBase="/usr/local/tomcat/webapps/test02" path="" reloadable="true"/>
</Host>
4.2 Tomcat 站点设置
[root@localhost ~]# cd /usr/local/tomcat/webapps/
[root@localhost webapps]# mkdir test01
[root@localhost webapps]# mkdir test02
[root@localhost webapps]# vim test01/index.jsp
<h1> this is test01 </h1>
[root@localhost webapps]# vim test02/index.jsp
<h1>this is test02 </h1>
4.3 dns解析服务配置
[root@localhost webapps]# yum -y install bind
[root@localhost webapps]# vim /etc/named.conf
listen-on port 53 {
any; };
allow-query {
any; };
[root@localhost webapps]# vim /etc/named.rfc1912.zones
zone "test01.com" IN {
type master;
file "test01.com.zone";
allow-update {
none; };
};
zone "test02.com" IN {
type master;
file "test02.com.zone";
allow-update {
none; };
};
[root@localhost named]# vim test01.com.zone
$TTL 1D
@ IN SOA @ rname.invalid. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS @
A 127.0.0.1
www IN A 192.168.233.127
~
[root@localhost named]# vim test02.com.zone
$TTL 1D
@ IN SOA @ rname.invalid. (
0 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS @
A 127.0.0.1
www IN A 192.168.233.127
4.4 启动服务
[root@localhost named]# shutdown.sh
[root@localhost named]# startup.sh
[root@localhost named]# systemctl start named