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

前言

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

一: Tomcat安装部署

1.1:Tomcat简介

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

1.2:Tomcat核心组件

  • Web容器
  • Servlet容器: 名为catalina处理Servlet代码,一般用于后端
  • JSP容器: 将JSP动态网页翻译成Serlet代码,一般用于前端

mark

mark

1.3:Tomcat处理请求的过程

1.3.1:请求过程基本解释

mark

  • 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.2:请求过程详细解释

  • 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

  • 例如:这幅图的流程更加场景化了

mark

1.4: Tomcat安装部署

  1. 上传与安装
[root@localhost ~]# iptables -F
[root@localhost ~]# setenforce 0
[root@localhost opt]# ls
apache-tomcat-9.0.16.tar.gz  jdk-8u201-linux-x64.rpm  rh
[root@localhost opt]# 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)
[root@localhost opt]# rpm -ivh jdk-8u201-linux-x64.rpm 
[root@localhost jdk1.8.0_201-amd64]# ls
bin             lib          src.zip
COPYRIGHT       LICENSE      THIRDPARTYLICENSEREADME-JAVAFX.txt
include         man          THIRDPARTYLICENSEREADME.txt
javafx-src.zip  README.html
jre             release
[root@localhost jdk1.8.0_201-amd64]# pwd
/usr/java/jdk1.8.0_201-amd64

  1. 设置JDK环境变量
[root@localhost jdk1.8.0_201-amd64]# 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@localhost jdk1.8.0_201-amd64]# source /etc/profile
[root@localhost jdk1.8.0_201-amd64]# java -version
java version "1.8.0_201"
Java(TM) SE Runtime Environment (build 1.8.0_201-b09)
Java HotSpot(TM) 64-Bit Server VM (build 25.201-b09, mixed mode)
  1. 启动与关闭服务
[root@localhost opt]# ls
apache-tomcat-9.0.16.tar.gz  jdk-8u201-linux-x64.rpm  rh
[root@localhost opt]# tar xzvf apache-tomcat-9.0.16.tar.gz 
[root@localhost opt]# ls
apache-tomcat-9.0.16         jdk-8u201-linux-x64.rpm
apache-tomcat-9.0.16.tar.gz  rh
[root@localhost opt]# mv apache-tomcat-9.0.16 /usr/local/tomcat                //修改目录并重新命名
[root@localhost bin]# /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
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Tomcat started.
[root@localhost bin]# netstat -ntap|grep 8080
tcp6       0      0 :::8080                 :::*                    LISTEN      11418/java  
[root@localhost bin]# ln -s /usr/local/tomcat/bin/startup.sh /usr/bin/          //添加到系统命令
[root@promote bin]# ln -s /usr/local/tomcat/bin/shutdown.sh /usr/bin/
[root@promote bin]# ll /usr/bin/
[root@localhost bin]# startup.sh
[root@localhost bin]# shutdown.sh

mark

1.5: 优化启动速度

[root@localhost bin]# vim /usr/java/jdk1.8.0_201-amd64/jre/lib/security/java.security 
securerandom.source=file:/dev/urandom    //把random修改为urandom  不依赖系统中断

1.6: 配置语法检查

  • catalina.sh   //主命令脚本
    configtest.sh  //语法检查脚本
    

1.7: 添加service管理

  • [root@localhost init.d]# vim tomcat
    #!/bin/bash
    #chkconfig: 35 86 89
    TOMCAT_HOME=/usr/local/tomcat
    TOMCAT_BIN=/usr/local/tomcat/bin
    start(){
      $TOMCAT_BIN/startup.sh
    }
    
    stop(){
      $TOMCAT_BIN/shutdown.sh
    }
    
    
    restart(){
     stop
     start
    }
    
    configtest(){
      $TOMCAT_BIN/configtest.sh
    }
    
    case "$1" in
       start)
          start;;
       stop)
          stop;;
       restart)
          restart;;
       status)
          status;;
       configtest)
          configtest;;
       *)
          echo '{start|stop|restart|configtest|status}'
    esac
    [root@localhost init.d]# chmod +x tomcat
    
    [root@localhost init.d]# service tomcat stop                //关闭
    Using CATALINA_BASE:   /usr/local/tomcat
    Using CATALINA_HOME:   /usr/local/tomcat
    Using CATALINA_TMPDIR: /usr/local/tomcat/temp
    Using JRE_HOME:        /
    Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
    [root@localhost init.d]# service tomcat start             //启动
    Using CATALINA_BASE:   /usr/local/tomcat
    Using CATALINA_HOME:   /usr/local/tomcat
    Using CATALINA_TMPDIR: /usr/local/tomcat/temp
    Using JRE_HOME:        /
    Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
    Tomcat started.
    
    

二: Tocat服务目录

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

三: 虚拟主机配置

3.1: 虚拟主机概述

  • 可能有时候公司会有多个项目需要运行,那么肯定不可能是一一台服务器上运行多个Tomcat 服务,这样会消耗太多的系统资源。此时,就需要使用到Tomcat 虚拟主机。例如现在新增两个域名www.kgc.top和www.accp.top,希望通过这两个域名访问到不同的项目内容。
    ##. 创建kgc和accp项目目录和文件##
    执行下面的命令,可以创建kgc.和accp项目目录和文件。

3.2: 创建虚拟主机

  1. 创建erbao和sanbao项目目录和文件
  2. 修改 Tomcat主配置文件
  3. 重启 Toma服务
  4. 测试

3.2.1: 创建首页目录和文件

  • [root@localhost ~]# mkdir /usr/local/tomcat/webapps/kgc
    [root@localhost ~]# echo "<h1>this is kgc page</h1>" > /usr/local/tomcat/webapps/kgc/index.jsp 
    [root@localhost ~]# mkdir /usr/local/tomcat/webapps/accp
    [root@localhost ~]# echo "<h1>this is accp page</h1>" > /usr/local/tomcat/webapps/accp/index.jsp
    

3.2.2: 配置域名解析服务

  • [root@promote bin]# vim /etc/named.conf   //修改两个any
    [root@promote bin]# vim /etc/named.rfc1912.zones 
    ......
    zone "kgc.com" IN {
            type master;
            file "kgc.com.zone";
            allow-update { none; };
    };
    zone "accp.com" IN {        type master;
            file "accp.com.zone";
            allow-update { none; };
    };
    [root@promote bin]# cp -p /var/named/named.localhost /var/named/kgc.com.zone
    [root@promote bin]# vim /var/named/kgc.com.zone
    www IN  A       192.168.100.160
    [root@promote bin]# cp -p /var/named/kgc.com.zone /var/named/accp.com.zone
    [root@promote named]# systemctl start named
    [root@promote named]# systemctl enable named
    
    

    mark

mark

3.2.3: 构建虚拟主机

[root@promote accp]# vim /usr/local/tomcat/conf/server.xml
//找到<Host name="localhost"  appBase="webapps" unpackWARs="true" autoDeploy="true">   成对添加Host
..........
    <Host name="www.accp.com"  appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
        <Context docBase="/usr/local/tomcat/webapps/accp" path="" reloadable="true"/>
      </Host>
     <Host name="www.kgc.com"  appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">
         <Context docBase="/usr/local/tomcat/webapps/kgc" path="" reloadable="true"/>
      </Host>
    </Engine>                                      //以下三行不用修改
  </Service>
</Server>

//Host name="www.accp.com"  域名
//appBase="webapps"  站点目录
//docBase="/usr/local/tomcat/webapps/accp 首页文件目录
[root@promote accp]# shutdown.sh
[root@promote accp]# startup.sh

mark

mark

四:Tomcat优化

4.1:Tomcat配置文件参数优化

  • 关于Tomcat主配置文件server.xml里面很多默认的配置项,但并不能满足业务需求,
    常用的优化相关参数如下
    1. maxThreads: Tomcat使用线程来处理接收的每个请求,这个值表示Tomcat可创建的最大的线程数,默认值是200。
    2. minSpareThreads: 最小空闲线程数,Tomcat启动时的初始化的线程数,表示即使没有人使用也开这么多空线程等待,默认值是10
    3. maxSpareThreads: 最大备用线程数,一旦创建的线程超过这个值,Tomcat 就会关闭不再需要的socket线程。默认值是-1 (无限制)。一般不需要指定
    4. URIEncoding: 指定Tomcat容器的URL编码格式,语言编码格式这块倒不如其它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:压缩类型,指定对哪些类型的文件进行数据压缩。
    13. noCompressionUserAgents=“gozilla, traviata”:对于以下的浏览器,不启用压缩。

4.2:配置与压测演示

  • 如果已经对代码进行了动静分离,静态页面和图片等数据就不需要Tomcat 处理了,那么也就不需要在Tomcat中配置压缩了。因为这里只有一台Tomcat服务器,而且压测的是Tomcat首页,会有图片和静态资源文件,所以这里启用压缩

  • 以上是一些常用的配置参数,还有好多其它的参数设置,还可以继续深入的优化,HTTPConnector 与AJP Connector 的参数属性值,可以参考官方文档的详细说明进行学习。链接地址http:// tomcat. apache. org/ tomcat-9. 0-doc/ config/http. htm1,下面开始对Tomcat配置文件优化进行前后的对比,

  • [root@localhost conf]# vim server.xml 
    <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"/>
    [root@localhost conf]# shutdown.sh
    [root@localhost conf]# startup.sh 
    
    
  • 压测演示

  • 环境win10 安装jdk Java环境

  • mark

mark

右击–属性–高级系统设置–环境变量–系统变量–修改Path

mark
mark
修改配置文件再进行压测

mark

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值