Web服务器群集--Tomcat部署与优化

前言

  • Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。
  • 对于一个初学者来说,可以这样认为,当在一台机器上配置好Apache 服务器,可利用它响应HTML(标准通用标记语言下的一个应用)页面的访问请求。实际上Tomcat是Apache 服务器的扩展,但运行时它是独立运行的,所以当你运行tomcat 时,它实际上作为一个与Apache 独立的进程单独运行的

1.Tomcat介绍

1.1 Tomcat简介

  • 免费的、开放源代码的Web应用服务器
  • Apache软件基金会( Apache Software Foundation)Jakarta项目中的一个核心项目
  • 由 Apache、Sun和一些公司及个人共同开发而成
  • 深受Java爱好者的喜爱,并得到部分软件开发商的认可
  • 是目前比较流行的Web应用服务器

网页支持:

静态网页:Apache,Ngint支持,网页类型后缀.html .htm
动态网页:Tomcat支持,网页类型后缀.jsp

1.2 Tomcat核心组件

  • Web容器:实现服务器功能;
  • Servlet容器: 名为catalina处理Servlet代码,最底层的真正实现网页,显示内容,一般用于后端;
  • JSP容器: 将JSP动态网页翻译成Serlet代码,一般用于前端。

1.3 Tomcat处理请求的过程

在这里插入图片描述

1)connector:连接器

  • 负责接受用户请求和消息报文的,将消息报文发往container
  • 一个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 设计的核心。

2)container:容器

  • Container是容器的父接口,该容器的设计用的是典型的责任链的设计模式,它由四个自容器组件构成,分别是Engine、Host、Context、Wrapper。这四个组件是负责关系,存在包含关系。
  • 是容器对外映射的接口,用于封闭和管理servlet

3)engine:引擎

  • Engine 容器比较简单,它只定义了一些基本的关联关系 Host 容器。是用来将用户的请求发往它下面的虚拟主机的,engine是加载虚拟主机的一个容器

4)host:虚拟主机

  • Host 是 Engine 的容器,一个 Host 在 Engine 中代表一个虚拟主机,这个虚拟主机的作用就是运行多个应用,它负责安装和展开这些应用,并且标识这个应用以便能够区分它们。它的子容器通常是 Context,它除了关联子容器外,还有就是保存一个主机应该有的信息

5)context:JSP前段页面

  • Context 代表 Servlet 的 Context,它具备了 Servlet 运行的基本环境,理论上只要有 Context 就能运行 Servlet 了。简单的 Tomcat 可以没有 Engine 和 Host。Context 最重要的功能就是管理它里面的 Servlet 实例,Servlet 实例在 Context 中是以 Wrapper 出现的。
  • 可以概括为管理servlet,是host虚拟主机的实体内容的指向

6)servlet:是包含html的java文件,其实是java语言的一个类,作用是处理代码

扩展:

jsp与servlet的区别如下
jsp:是包含java程序的html文件。展示前端页面的
servlet:是包含html的java文件,后台实际执行具体操作的组件

1.4 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。

2.部署Tomcat

  • Tomcat上Apache下的一个子项目,它具备Web服务器的所有功能,不仅可以监听接受请求并响应静态资源,而且可以在后端运行特定规范的Java代码Servlet,同时将执行的结果以HTML代码的形式返回客户端

2.1 上传与安装

  • 导入两个软件包
    apache-tomcat-8.5.16.tar.gz
    jdk-8u91-linux-x64.tar.gz

在这里插入图片描述

[root@server ~]# tar zxvf jdk-8u91-linux-x64.tar.gz	
		'//不需要配置编译安装,这是一个现成的打包的软件,解压后即可使用'
[root@server ~]# mv jdk1.8.0_91/ /usr/local/java
[root@server ~]# cd /usr/local/java/
[root@server java]# ls -lh	//查看下载的文件
[root@server java]# cd

2.2 设置JDK环境变量

[root@server ~]# vi /etc/profile
...//末尾添加以下配置
export JAVA_HOME=/usr/local/java	'//定义变量,设为全局变量(设置JAVA的根目录)'
export JAVA_JRE=/usr/local/java/jre
export PATH=$PATH:$JAVA_HOME/bin:$JAVA_HOME/lib:$JAVA_JRE/bin:$JAVA_JRE/lib

[root@server ~]# source /etc/profile	'//将java脚本导入到环境变量使其生效'
[root@server ~]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/usr/local/java/bin:/usr/local/java/lib:/usr/local/java/jre/bin:/usr/local/java/jre/lib
[root@server ~]# java -version	'//查看版本信息'
openjdk version "1.8.0_131"
OpenJDK Runtime Environment (build 1.8.0_131-b12)
OpenJDK 64-Bit Server VM (build 25.131-b12, mixed mode)

在这里插入图片描述

2.3 启动并验证java服务

[root@server ~]# vi kp.java
public class kp {
    
    
        public static void main (String[] args) {
    
    
         System.out.println("hello world!!");
}
}
[root@server ~]# javac kp.java
[root@server ~]# java kp
hello world!!

2.4 安装配置Tomcat

2.4.1 解包并移动文件夹到指定位置

[root@server ~]# tar zxvf apache-tomcat-8.5.16.tar.gz
[root@server ~]# mv apache-tomcat-8.5.16 /usr/local/tomcat8
[root@server tomcat8]# ls -lh	//查看安装后的内容
[root@server tomcat8]# cd

2.4.2 软链接脚本文件

[root@server ~]# ln -s /usr/local/tomcat8/bin/startup.sh /usr/bin/tomcatup		//链接脚本文件
[root@server ~]# ln -s /usr/local/tomcat8/bin/shutdown.sh /usr/bin/tomcatdown

2.4.3 启动tomcat服务并验证

[root@server ~]# tomcatup	//启动tomcat服务
[root@server ~]# netstat -anpt | grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN      53096/java 
  • 访问网址,如图所示

在这里插入图片描述

2.5 创建站点目录及测试页面

2.5.1 创建站点目录

[root@server ~]# mkdir -p /web/app1	
[root@server ~]# mkdir -p /web/app2
[root@server ~]# vi /web/app1/index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>JSP Web 1</head>
<body>
<% out.println("Welcome!This is web1.");%>
<div>动态页面</div><br><img src="a.jpg" />
</body>
</html>
'//这个JSP中引入的 page 标签'
'//language 表示语言是java'
'//import 类似于java 类中的import就是把包导入进来,这样在jsp才可以调用包中的类'
'//pageEncoding 表示页面的编码格式'

2.5.2 导入图片素材

[root@server ~]# cd /web/app1
[root@server app1]# 		//需要导入图片,准备素材a.jpg

在这里插入图片描述

2.5.3 引用目录

[root@server ~]#vi /usr/local/tomcat8/conf/server.xml	 //到配置文件中引用目录
...
      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
<Context docBase="/web/app1" path="" reloadable="false">	//添加Context模块配置
</Context>

2.5.4 重启Tomcat服务

[root@server ~]# tomcatdown
Using CATALINA_BASE:   /usr/local/tomcat8
Using CATALINA_HOME:   /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME:        /usr/local/java
Using CLASSPATH:       /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar

[root@server ~]# tomcatup
Using CATALINA_BASE:   /usr/local/tomcat8
Using CATALINA_HOME:   /usr/local/tomcat8
Using CATALINA_TMPDIR: /usr/local/tomcat8/temp
Using JRE_HOME:        /usr/local/java
Using CLASSPATH:       /usr/local/tomcat8/bin/bootstrap.jar:/usr/local/tomcat8/bin/tomcat-juli.jar
Tomcat started.
[root@server ~]# netstat -anpt | grep 8080	//检查Tomcat端口是否开启
tcp6       0      0 :::8080                 :::*                    LISTEN      53310/java 

2.5.5 验证结果

在浏览器上访问,效果如下
在这里插入图片描述

2.6 Tomcat通过域名的访问

在之前的环境下进行配置

[root@server ~]# vi /usr/local/tomcat8/conf/server.xml
...
      <Host name="www.zz.com"  appBase="webapps"	//更改域名为www.zz.com
  • 重启Tomcat服务
[root@server ~]# tomcatdown
[root@server ~]# tomcatup
  • 准备另一台客户机,添加映射
[root@server2 ~]# vi /etc/hosts
...
192.168.140.15 www.zz.com	//添加的映射
  • 在该客户机上访问,查看效果

在这里插入图片描述

2.7 Tomcat基于虚拟主机配置

2.7.1 基于域名的访问

  • 在基于域名访问的环境下,进行配置
[root@server ~]# cp /web/app1/index.jsp /web/app2
[root@server ~]# vi /web/app2/index.jsp 
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<html>
<head>JSP Web 2</head>
<body>
<% out.println("Welcome!This is web2.");%>
<div>动态页面2</div><br><img src="b.png" />
</body>
</html>
[root@server ~]# cd /web/app2
[root@server app2]# 		//需要导入图片,准备素材b.png

在这里插入图片描述

[root@server ~]# vi /usr/local/tomcat8/conf/server.xml
...	//在第一个</Host name>模块结束后添加一个类似的模块
         <Host name="www.yy.com"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">
        <Context docBase="/web/app2" path="" reloadable="false">
        </Context>
      </Host>
  • 重启服务,检查端口状态
[root@server ~]# tomcatdown
[root@server ~]# tomcatup
[root@server ~]# netstat -anpt | grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN      53899/java          
tcp6       0      0 ::1:57824               ::1:8080                TIME_WAIT   -  
  • 在另一台客户机上,添加映射
[root@server2 ~]# vi /etc/hosts
...
192.168.140.15 www.zz.com www.yy.com //添加的映射
  • 在该客户机上访问www.yy.com:8080 出现设置的动态页面

在这里插入图片描述

2.7.2 基于端口的访问

在之前的环境下,删除添加的第二个</Host name...>模块,
在末尾</Server>之前,添加新的<server name...>模块
[root@server ~]# vi /usr/local/tomcat8/conf/server.xml
...
<Service name="Catalina2">
	<Connector port="8090" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /><Engine name="Catalina2" defaultHost="localhost">
	<Host name="www.yy.com" appBase="webapps" unpackWARs="true" autoDeploy="true">
	<Context docBase="/web/app2" path="" reloadable="false">
	</Context>
	</Host>
	</Engine>
</Service>
</Server>
  • 重启服务,检查端口状态
[root@server ~]# tomcatdown
[root@server ~]# tomcatup
[root@server ~]# netstat -anpt | grep java
tcp6       0      0 :::8080                 :::*                    LISTEN      54259/java          
tcp6       0      0 :::8090                 :::*                    LISTEN      54259/java          
tcp6       0      0 127.0.0.1:8005          :::*                    LISTEN      54259/java          
tcp6       0      0 :::8009                 :::*                    LISTEN      54259/java  
  • 在另一台客户机上访问www.yy.com:8090 出现设置的动态页面

在这里插入图片描述

3.Tocat服务目录

bin
存放启动和关闭Tomcat 的脚本文件,比较常用的是catalina. sh、startup. sh、shutdown. sh三个文件
conf
存放Tomcat 服务器的各种配置文件,比较常用的是server. xm1、 context. xm1、tomcat -users. xml、 web. xml四个文件。
lib
存放Tomcat 服务器的jar包,一般不作任何改动,除非连接第三方服务,比如redis,那就需要添加相对应的jar包
logs,
存放Tomcat 日志
temp
存放Tomcat 运行时产生的文件
webapps.
存放项目资源的目录
work
Tomcat 工作目录,一般清除Tomcat缓存的时候会使用到

4.Tomcat优化

4.1 优化方向

  • 操作系统优化(内核参数优化)
  • Tomcat配置文件参数优化
  • Java虚拟机(JVM)调优

4.2 Tomcat配置文件参数优化

  • Tomcat主配置文件server.xml常用的配置参数
  • Tomcat配置文件参数优化
1.maxThreads: Tomcat 使用线程来处理接收的每个请求,这个值表示Tomcat 可创建的  最大的线程数,默认值是2002.minSpareThreads: 最小空闲线程数,Tomcat 启动时的初始化线程数,表示即使没有人使用也开这么多空线程等待,默认值是103.maxSpareThreads: 最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket 线程。默认值是 -1 (无限制),一般不需要指定。

4.URIEncoding: 指定Tomcat 容器的URL编码格式,Tomcat 语言编码格式这块不如其它Web 服务器软件配置方便,需要分别指定。

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

6.enableLookups: 是否反查域名,以返回远程主机的主机名,取值为: truefalse,如果设置为false,则直接返回IP地址,为了提高处理能力,应设置为false7.disableUploadTimeout:上传时是否使用超时机制。应设置为true8.connectionUploadTimeout:上传超时时间,毕竟文件上传可能需要消耗更多的时间,该参数需要根据自己的业务需要自行调整,以使Servlet 有较长的时间来完成它的执行,需要与上一个参数一起配合使用才会生效。

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

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

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

12.compressableMimeType:压缩类型,指定对哪些类型的文件进行数据压缩。

13.noCompressionUserAgents=” gozilla, traviata": 对于以下的浏览器,不启用压缩

猜你喜欢

转载自blog.csdn.net/weixin_42449832/article/details/110532457