• Tomcat基础与优化


    Tomcat介绍

    Tomcat服务器是一个免费的开放源代码的Web应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,Tomcat具有处理HTML页面的功能,通常作为一个Servlet和JSP容器,单独运行在后端。

    Tomcat核心组件

    web容器

    完成web服务器的功能

    Servlet 容器

    名字为catalina,用于处理servlet代码

    JSP容器

    用于将JSP动态网页翻译成servlet代码

    Tomcat功能组件

    核心功能有两个:一个是负责接收和反馈外部请求的连接器Connector

    ​ 另一个是负责处理请求的容器Container

    Connector

    连接器:负责对外接收和响应请求。它是ocat与外来的交通纽,监听端口接收外界请求,并将请求处理后传递给容器做业务处理,最后将容器处理后的结果响应终外界。

    Container

    容器:负责对内处理业务逻辑。其内部由 Engine、Host、Context和mrapper 四个容器组成,用于管理和调用 Servlet 相关逻辑。

    1. Engine:引擎,用来管理多个虚拟主机,一个 container最多只能有一个engine
    2. Host:代表一个虚拟主机,也可以叫站点,通过配置 Host 就可以添加站点
    3. context:代表一个 web 应用,包含多个 Servlet 封装器
    4. Wrapper: 封装器,容器的最底层。每一 wrapper 封装着一个 Servlet,负责对象实例的创建、执行和销毁功能

    Tomcat的部署

    安装jdk

    #需要登录下载:https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html
    
    下载后将软件包拖进虚拟机文件夹中
    [root@localhost opt]#ls
    jdk-8u201-linux-x64.rpm  rh
    
    [root@localhost opt]#rpm -ivh jdk-8u201-linux-x64.rpm
    [root@localhost opt]#cd /usr/java
    [root@localhost java]#ls
    default  jdk1.8.0_201-amd64  latest
    [root@localhost java]#cd jdk1.8.0_201-amd64/
    [root@localhost jdk1.8.0_201-amd64]#ls
    bin             jre      README.html                         THIRDPARTYLICENSEREADME.txt
    COPYRIGHT       lib      release
    include         LICENSE  src.zip
    javafx-src.zip  man      THIRDPARTYLICENSEREADME-JAVAFX.txt
    [root@localhost jdk1.8.0_201-amd64]#ls bin
    appletviewer  javac           javaws    jinfo       jsadebugd     orbd         serialver
    ControlPanel  javadoc         jcmd      jjs         jstack        pack200      servertool
    extcheck      javafxpackager  jconsole  jmap        jstat         policytool   tnameserv
    idlj          javah           jcontrol  jmc         jstatd        rmic         unpack200
    jar           javap           jdb       jmc.ini     jvisualvm     rmid         wsgen
    jarsigner     javapackager    jdeps     jps         keytool       rmiregistry  wsimport
    java          java-rmi.cgi    jhat      jrunscript  native2ascii  schemagen    xjc
    
    [root@localhost jdk1.8.0_201-amd64] vim /etc/profile #环境变量主配置文件
    [root@localhost jdk1.8.0_201-amd64] cd /etc/profile.d/
    [root@localhost profile.d]#ls
    256term.csh                   colorgrep.csh  flatpak.sh  less.sh        vte.sh
    256term.sh                    colorgrep.sh   lang.csh    PackageKit.sh  which2.csh
    abrt-console-notification.sh  colorls.csh    lang.sh     vim.csh        which2.sh
    bash_completion.sh            colorls.sh     less.csh    vim.sh
    [root@localhost profile.d] 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:$JRE_HOME
    export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$PATH
    
    [root@localhost profile.d]#source java.sh #运行
    [root@localhost profile.d]#java -version #查看jdk版本
    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)
    
    [root@localhost ~]#cd
    [root@localhost ~]#vim Hello.java  #编写一个java代码文件,测试jdk是否正常使用
    public class Hello {
       public static void main(String[] args){
         System.out.println("Hello World!");
      }
    }
    [root@localhost ~]#javac Hello.java #编译文件生成二进制文件
    [root@localhost ~]#ls
    anaconda-ks.cfg  Hello.java            公共  视频  文档  音乐
    Hello.class      initial-setup-ks.cfg  模板  图片  下载  桌面
    
    [root@localhost ~]#java Hello #运行java代码
    Hello World!
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59

    安装Tomcat

    https://tomcat.apache.org/ #没有软件包到tomcat官网下载
    [root@localhost ~]#cd /opt
    [root@localhost opt]#ls
    apache-tomcat-9.0.16.tar.gz  jdk-8u201-linux-x64.rpm  rh
    [root@localhost opt]#tar xf apache-tomcat-9.0.16.tar.gz
    [root@localhost opt]#ls
    apache-tomcat-9.0.16  apache-tomcat-9.0.16.tar.gz  jdk-8u201-linux-x64.rpm  rh
    [root@localhost opt]#mv apache-tomcat-9.0.16 /usr/local/tomcat
    [root@localhost opt]#cd /usr/local/
    [root@localhost local]#ls
    bin  etc  games  include  lib  lib64  libexec  sbin  share  src  tomcat
    [root@localhost local]#cd tomcat
    [root@localhost tomcat]#ls
    bin           conf             lib      logs    README.md      RUNNING.txt  webapps
    BUILDING.txt  CONTRIBUTING.md  LICENSE  NOTICE  RELEASE-NOTES  temp         work
    [root@localhost tomcat]#ls bin
    bootstrap.jar       commons-daemon-native.tar.gz  makebase.sh       tomcat-juli.jar
    catalina.bat        configtest.bat                setclasspath.bat  tomcat-native.tar.gz
    catalina.sh         configtest.sh                 setclasspath.sh   tool-wrapper.bat
    catalina-tasks.xml  daemon.sh                     shutdown.bat      tool-wrapper.sh
    ciphers.bat         digest.bat                    shutdown.sh       version.bat
    ciphers.sh          digest.sh                     startup.bat       version.sh
    commons-daemon.jar  makebase.bat                  startup.sh
    [root@localhost tomcat]#cd bin
    [root@localhost bin]#./startup.sh  #运行Tomcat服务
    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 bin]#netstat -lnpt | grep :8080 #查看端口号
    tcp6       0      0 :::8080                 :::*                    LISTEN      49173/java 
    在网页输入网址http://192.168.65.101:8080/
    
    另一种启动方法
    [root@localhost bin]#cd /usr/lib/systemd/system
    [root@localhost system]#vim tomcat.service  #编写Tomcat.service文件,可以使用systemctl启动
    [Unit]
    Description=Tomcat
    After=syslog.target network.target
    
    [Service]
    Type=forking
    Environment="JAVA HOME=/usr/iava/idk1.80 201_amd64"
    Environment="PATH=SJAVA HOME/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin"
    Environment="CLASSPATH=.:$JAVA HOME/ib/dtjar:$JAVA HOME/ib/tools.jar"
    ExecStart=/usr/local/tomcat/bin/startup.sh
    ExecStop=/usr/local/tomcat/bin/shutdown.sh
    Restart=on-failure
    
    [Install]
    WantedBy=multi-user.target
    
    [root@localhost system]#systemctl daemon-reload #重新加载
    [root@localhost system]#systemctl start tomcat #开启Tomcat服务
    [root@localhost system]#ss -ntap |grep 8080
    LISTEN     0      100         :::8080                    :::*                   users:(("java",pid=50085,fd=54))
    在网页输入网址http://192.168.65.101:8080/
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59

    在这里插入图片描述

    Tomcat配置文件

    安装目录下文件介绍

    目录名字功能
    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 日志
    temp存放 Tomcat 运行时产生的文件
    webapps存放项目资源的目录
    workTomcat 工作目录,一般清除 Tomcat 缓存的时候会使用到(升级版本时注意要删除里面的缓存)

    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.propertiesTomcat环境变量的配置,用于设定类加载器路径,以及一些与JVM调优相关参数
    logging.propertiesTomcat日志系统相关的配置,可以修改日志级别和日志路径等

    tomcat虚拟配置主机

    创建项目目录和文件

    [root@localhost ~]#systemctl stop firewalld.service
    [root@localhost ~]#setenforce 0
    [root@localhost ~]#cd /usr/local/
    [root@localhost local]#ls
    bin  etc  games  include  lib  lib64  libexec  sbin  share  src  tomcat
    [root@localhost local]#cd tomcat/
    [root@localhost tomcat]#ls
    bin           conf             lib      logs    README.md      RUNNING.txt  webapps
    BUILDING.txt  CONTRIBUTING.md  LICENSE  NOTICE  RELEASE-NOTES  temp         work
    [root@localhost tomcat]#cd webapps/  #存放项目的文件夹
    [root@localhost webapps]#mkdir test1 test2
    [root@localhost webapps]#cd test1
    [root@localhost test1]#echo '

    this is test1 page!

    ' >index.html
    [root@localhost webapps]#cd test2 [root@localhost test2]#echo '

    this is test2 page!

    ' >index.html
    [root@localhost test2]#cd .. [root@localhost webapps]#ls docs examples host-manager manager ROOT test1 test2
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    修改Tomcat主配置文件 server.xml

    [root@localhost conf]#cd /usr/local/tomcat/conf
    [root@localhost conf]#ls
    Catalina             context.xml           logging.properties  tomcat-users.xsd
    catalina.policy      jaspic-providers.xml  server.xml          web.xml
    catalina.properties  jaspic-providers.xsd  tomcat-users.xml
    [root@localhost conf]#vim server.xml   # Tomcat的主配置文件
    将下面加入Engine标签中
    <Host name="www.test1.com" appBase="webapps"
                unpackWARs="true" autoDeploy="true">
            <Context docBase="/usr/local/tomcat/webapps/test1" path="" reloadable="true">
            </Context>
          </Host>
          <Host name="www.test2.com" appBase="webapps"
                unpackWARs="true" autoDeploy="true">
            <Context docBase="/usr/local/tomcat/webapps/test2" path="" reloadable="true">
            </Context>
          </Host>
    
    [root@localhost conf]#systemctl start tomcat
    [root@localhost conf]#netstat -lnpt |grep 8080
    tcp6       0      0 :::8080                 :::*                    LISTEN      3769/java  
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    修改host

    [root@localhost etc]#vim /etc/hosts
    192.168.65.101 www.test1.com www.test2.com
    在浏览器输入www.test1.com 和 www.test2.com
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    在这里插入图片描述

    Tomcat优化

    配置文件优化

    常用参数解释
    redirectPort如果某连接器支持的协议是HTTP,当接收客户端发来的HTTPS请求时,则转发至此属性定义的 8443 端口。
    maxThreads表示Tomcat可创建的最大的线程数,即支持的最大并发连接数,默认值是 200
    minSpareThreads最小空闲线程数。表示即使没有人使用也开这么多空线程等待,默认值是 10
    maxSpareThreads创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。默认值是-1
    processorCache进程缓冲器,可以提升并发请求。默认值是200
    URIEncoding指定 Tomcat 容器的 URL 编码格式
    connnectionTimeout网络连接超时,单位:毫秒,通常默认 20000 毫秒就可以
    enableLookups是否反查域名,以返回远程主机的主机名,取值为:true 或 false,通常为false
    disableUploadTimeout上传时是否使用超时机制。应设置为 true
    connectionUploadTimeout上传超时时间
    acceptCount指定当所有可以使用的处理请求的线程数都被使用时,可传入连接请求的最大队列长度,默认100个
    maxKeepAliveRequests长连接的最大请求数。默认长连接是打开的,设置为1时,代表关闭长连接
    compression是否对响应的数据进行GZIP压缩,off:表示禁止压缩;on:表示允许压缩
    compressionMinSize表示压缩响应的最小值
    compressableMimeType压缩类型,指定对哪些类型的文件进行数据压缩
    查看进程数
    top -H
    ps -T
    
    • 1
    • 2
    • 3

    系统内核优化

    [root@www ~]#vim /etc/security/limits.conf
    # can be one of the following:
    #        - core - limits the core file size (KB)  限制内核文件的大小
    #        - data - max data size (KB)  最大数据大小
    #        - fsize - maximum filesize (KB)  最大文件大小
    #        - memlock - max locked-in-memory address space (KB) 最大锁定内存地址空间
    #        - nofile - max number of open file descriptors 打开文件的最大数目
    #        - rss - max resident set size (KB)  最大持久设置大小
    #        - stack - max stack size (KB) 最大栈大小
    #        - cpu - max CPU time (MIN)  最多CPU时间
    #        - nproc - max number of processes 进程的最大数目
    #        - as - address space limit (KB)  地址空间限制
    #        - maxlogins - max number of logins for this user 此用户允许登录的最大数目
    #        - maxsyslogins - max number of logins on the system 系统允许登录的最多用户数
    #        - priority - the priority to run user process with 用户进程的优先级运行
    #        - locks - max number of file locks the user can hold 用户可以持有的文件锁最大数量
    #        - sigpending - max number of pending signals 未处理信号的最大数量
    #        - msgqueue - max memory used by POSIX message queues (bytes) 内存使用最大POSIX消息队列
    #        - nice - max nice priority allowed to raise to values: [-20, 19] 允许的最大优先级
    #        - rtprio - max realtime priority-最大实时优先
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    [root@www ~]#vim /etc/sysctl.conf  主配置文件
    /etc/sysctl.d/子配置文件
    
    /etc/security/limits.conf 
    nofile 
    nproc  
    memlock
    /etc/sysct1.conf   
    net .ipv4.tcp_tw_reuse=1   
    net.ipv4.tcp_tw_recycle=1  
    net.ipv4.tcp_fin_timeout=30  
    net.ipv4.tcp_max_tw_buckets=5000              net.ipv4.ip_local_port_range=1024 65535
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    lvm优化

    -Xms  	#设置应用程序初始使用的堆内存大小(年轻代+老年代)	-Xms2g
    -Xmx	#设置应用程序能获得的最大堆内存早期JVM不建议超过32G,内存管理效率下降	-Xms4g
    -XX:NewSize	#设置初始新生代大小	-XX:NewSize=128m
    -XX:MaxNewSize	#设置最大新生代内存空间	-XX:MaxNewSize=256m
    -Xmnsize	#同时设置-XX:NewSize 和 -XX:MaxNewSize,代	-Xmn1g
    -XX:NewRatio	#以比例方式设置新生代和老年代	-XX:NewRatio=2new/old=1/2
    -XX:SurvivorRatio	#以比例方式设置eden和survivor(S0或S1	-XX:SurvivorRatio=6eden/survivor=6/1new/survivor=8/1
    -Xss	#设置每个线程私有的栈空间大小,依据具体线程	-Xss256k
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    在 catalina.sh 中设置 JAVA_OPTS 参数。

    **在 catalina.sh 中设置 JAVA_OPTS 参数。**
    JAVA OPTS="$JAVA_OPTS -server -Xms2048m -Xmx2046m -Xx:PermSize-1024m -XX:MaxPermSize=1024m -Xmn768m"
    
    -server #表示启用JDK的server模式,实现在多核服务器性能更佳 
     
    -Xms2048m 
    -Xmx2048m #设置JVM堆内存初始值和最大值一样大,一般设置为物理内存的 1/2
    
    -XX:Permsize=1024m 
    -XX:MaxPermsize=1024m
    #设置永久代《非堆内存) 初始值和最大最一样大,一般设置为物理内存的 1/4
    
    初始值和最大最设置一样大的原因?
    可以减少GC次数和内存伸缩带来的频繁内存中请,从而减少一定的系统开销。
            
    -Xmn #设置JVM堆内存新生代的大小,一般设置为堆内存的 3/8
    
    -xx:ParallelGCThreads=-2 #设置并行GC(垃圾回收) 线程数,提高垃圾回收效率 
    -XX:+HeapDumpOnOutOfMemoryError  -XX:HeapDumpPath=/usr/local/tomcat/temp/oom.hprof  #设置进程发生OOM异常退出会进行DUMP备份
    -XX:+DisableExplicitGc #禁止调用System.gc()方法,防止误调用系统gc方法导致系统的JVM堆内存大起大落而使系统响应效率严重降低
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
  • 相关阅读:
    大厂 Framework 面试必备 Handler&Binder 面试题
    1.Spring的简单使用
    记录--CSS 滚动驱动动画 scroll()
    多卡聚合智能融合通信设备在无人机无线视频传输应用
    C++面试常见问题:手写String类
    Zemax操作36--一个选择初始结构的例子
    校园智慧党建小程序源码系统 带完整的搭建教程
    测试开发环境下centos7.9下安装docker的minio
    使用taichi 写了一个任意平台任意显卡推理的Linear
    第三周晨考自测(3.0)
  • 原文地址:https://blog.csdn.net/Meng2453508284/article/details/133350595