linux Tomcat

摘要:Tomcat非常重要的一种服务,三个容器,web容器,jsp容器,servlet容器,可以实现web服务。

目录

一、tomcat原理
二、tomcat核心组件
三、tomcat处理请求
四、tomcat部署
五、tomcat主要目录
六、tomcat虚拟机配置
七、tomcat优化
八、tomcat多实例部署
九、java虚拟机调优

 

 

 

 

 

 

 

 

一、tomcat原理

    1.tomcat概念

      Tomcat是Java 语言开发的,Tomcat 服务器是一个免费的开放源代码的Web应用服务器,Tomcat属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试 JSP 程序的首选。

    2.tomcat优缺点

       (1)优点:tomcat轻量级,性能高,功能全,可以处理静态和动态网页。
      (2)缺点:Tomcat 虽然和Apache 或者Nginx这些Web服务器一样,具有处理HTML页面的功能,然而由于其处理静态HTML的能力远不及Apache 或者Nginx,所以Tomcat 通常是作为一个Servlet 和 JSP 容器,单独运行在后端。

 

二、tomcat核心组件

     1.核心的组件

      (1)web容器: 完成Web服务器的功能。接收用户的请求,响应用户的请求,完成web服务的功能tomcat web 应用服务,web可以通过http(s)来访问的一个页面,文件web容器封装了一组文件集中化管理一组组员对象,展示web 动态页面。

      (2)Servlet 容器: 名字为catalina,用于处理Servlet 代码。用来实现用Java语言开发的动态页面逻辑,Servlet是 Java Servlet的简称,可以理解为是一一个服务连接器,是用Java编写的服务器端程序,具有独立于平台和协议的特性。简单的理解:servlet 就是一 个中间件,包含了接口和方法,将客户端和数据库连接,从而实现动态网页的创建。

      (3)JSP容器: 用于将JSP动态网页翻译成Servlet 代码。JSP全称Java Server Pages, 是一种动态网页开发技术。|它使用JSP 标签在HTML网页中插入Java 代码。标签通常以<%开头,以%>结束。JSP是一种Java servlet,主要用于实现Java web应用程序的用户界面部分。JSP通过网页表单获取用户输入数据、访问数据库及其他数据源,然后动态地创建网s页。

    2.tomcat组件工作流程

      当用户进行访问,通过8080端口发送请求,web容器接收请求,将受到请求给jsp容器翻译为servlet,处理完后将结果返回给web展示给用户看。因此 Tomcat 是 Web 应用服务器,也是一个 Servlet/JSP 容器。Tomcat 作为 Servlet容器,负责处理客户请求,把请求传送给 Servlet,并将 Servlet 的响应传送回给客户

   3.Tomcat 功能组件结构

    (1)负责处理请求的容器 Container,负责对内处理业务逻辑。其内部由 Engine、Host、Context和Wrapper 四个容器组成,用于管理和调用 Servlet 相关逻辑。

    (2)外部请求的连接器 Connector,负责对外接收和响应请求。它是Tomcat与外界的交通枢纽,监听端口接收外界请求,并将请求处理后传递给容器做业务处理,最后将容器处理后的结果响应给外界。

   4.Container 结构分析

    每个 Service 会包含一个 Container 容器。在 Container 内部包含了 4 个子容器:

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

    Engine、Host、Context 和 Wrapper,这四个容器之间属于父子关系。

        容器 由一个引擎可以管理多个虚拟主机。每个虚拟主机可以管理多个 Web 应用。每个 Web 应用会有多个 Servlet 封装器。


三、tomcat处理请求

  1.Tomcat 请求过程

    (1)用户在浏览器中输入网址,请求被发送到本机端口 8080,被在那里监听的 Connector 获得;

    (2)Connector 把该请求交给它所在的 Service 的 Engine(Container)来处理,并等待 Engine 的回应;
    (3)请求在 Engine、Host、Context 和 Wrapper 这四个容器之间层层调用,最后在 Servlet 中执行对应的业务逻辑、数据存储等。
    (4)执行完之后的请求响应在 Context、Host、Engine 容器之间层层返回,最后返回给 Connector,并通过 Connector 返回给客户端。


四、tomcat部署

  1.Tomcat的部署

    (1)关闭防火墙,将安装 Tomcat 所需软件包传到/opt目录下

   

   (2)安装JDK

    查看jdk文件

     按照jdk

   查看版本

 

(3)设置JDK环境变量

   

 

 

   刷新全局配置文件

   (4)创建java文件验证java是否安装成功

 

   (5)安装启动Tomcat

   将tomcat文件移动到tomcat下。

   (6)启动tomcat

    后台启动:可以在后台运行tomcat

      /usr/local/tomcat/bin/startup.sh或/usr/local/tomcat/bin/catalina.sh start

     前台启动:窗口不能关闭,否则tomcat结束。

      /usr/local/tomcat/bin/catalina.sh run

 

   查看端口是否启动

   网页验证,tomcat确定启动。

   (7)优化速度

    dev/urandom是/dev/random的非阻塞版本

 

 

五、tomcat主要目录

   1.tomcat主要目录

    (1)bin:存放启动和关闭Tomcat的脚本文件,比较常用的是 catalina.sh、startup.sh、shutdown.sh三个文件

    (2)conf:存放Tomcat 服务器的各种配置文件,比较常用的是 server.xml、context.xml、tomcat-users.xml、web.xml 四个文件。  
        ① server.xml: Tomcat的主配置文件,包含Service,Connector,Engine,Realm,Valve,Hosts主组件的相关配置信息;
        ② context.xml:所有host的默认配置信息;
        ③ tomcat-user.xml:Realm认证时用到的相关角色、用户和密码等信息,Tomcat自带的manager默认情况下会用到此文件,在Tomcat中添加/删除用户,为用户指|定角色等将通过编辑此文件实现;
        ④ web.xml:遵循Servlet规范标准的配置文件,用于配置servlet,并为所有的web应用程序提供包括MIME映射等默认配置信息;
    (3)lib:存放Tomcat运行需要的库文件的jar 包,一般不作任何改动,除非连接第三方服务,比如 redis,那就需要添加相对应的jar 包
    (4)logs:存放 Tomcat 执行时的日志
    (5)temp:存放 Tomcat 运行时产生的文件
    (6)webapps:存放 Tomcat 默认的 Web 应用部署目录
    (7)work:Tomcat工作日录,存放jsp编译后产生的class文件,一般清除Tomcat缓存的时候会使用到
    (8)src:存放Tomcat 的源代码
    (9)doc:存放Tomcat文档


六、tomcat虚拟机配置

    1.tomcat虚拟机配置

 

         (1)创建 hjp 和 zhansan 项目目录和文件   

 

 

    (2)修改 Tomcat 主配置文件 server.xml

 

   

   (4)网页验证

 

 

 

七、tomcat优化

    1.tomcat优化

      (1)random,优化启动速度,默认是阻塞状态,速度慢,将其改为urandom变为非阻塞状态。

      (2)protocol,连接协议,默认是"HTTP/1.1"合适的连接协议会服务运行增加速度。

      (3)maxThreads,最大线程数,默认最大线程数是200,但是200一般在生产中不够,可以增加。

      (4)minSpareThreads,最小空闲数,默认最小空闲数是10,这是指开启tomcat时就启用的进程,10个在生产环境中不够,一般配置50-80。

      (5)maxSpareThreads,最大备用线程数,默认-1,代表无限制,不用改。

      (6)URLEncoding,URL编码,默认UTF-8,中文简体。

      (7)ConnetionTimeout,是否开启连接超时,防止有的线程不结束占用资源。

      (8)disableUploadTimeout,是否使用上传超时,默认为true。

      (9)enableLookups,是否反查域名,默认flash,不会陷入死循环占用资源,直接返回ip地址。

      (10)acceptCount,连接请求最大队列长度,默认为100,可以修改。

      (11)compression,是否开启压缩。

      (12)Compressionminsize,最小压缩大小,默认2048,代表超过2048才会压缩。

      (13)compressableMinetype,压缩类型,可以设置压缩为什么类型。

      (14)noCompressionUserAgents="gozille,traviata"对于以下浏览器不启用压缩。

    2.优化实例

 

  

 

 

八、tomcat多实例部署

    1.tomcat多实例部署

 

      (1)安装好 jdk
      (2)安装 新的tomcat

        解压文件

         复制两份文件到两个tomcat

     (3)配置全局配置文件

 

     (4)修改 tomcat2 中的 server.xml 文件,要求各 tomcat 实例配置不能有重复的端口号

      tomcat1

 

 

     (5)修改各 tomcat 实例中的 startup.sh 和 shutdown.sh 文件,添加 tomcat 环境变量

      tomcat1:

 

     tomcat2:

    

 

   (6)启动各 tomcat 中的 /bin/startup.sh 

     查看端口号是否开启

   (7)浏览器访问测试

 

 

 

九、java虚拟机调优

     1.java虚拟机调优

        /bin/catalina.sh

        -server:jvm的server工作模式,对应的有client工作模式。使用“java -version”可以查看当前工作模式。

    2.调优内容

      -Xms1024m:初始Heap大小,使用的最小内存
      -Xmx1024m:Java heap最大值,使用的最大内存。经验: 设置Xms大小等于Xmx大小
      -XX:NewSize=512m:表示新生代初始内存的大小,应该小于 -Xms的值
      -XX:MaxNewSize=1024M:表示新生代可被分配的内存的最大上限,应该小于 -Xmx的值
      -XX:PermSize=1024m:设定内存的永久保存区域,内存的永久保存区域,VM 存放Class 和 Meta
        信息,JVM在运行期间不会清除该区域
      -XX:MaxPermSize=1024m:设定最大内存的永久保存区域。经验: 设置PermSize大小等于
        MaxPermSize大小
      -XX:+DisableExplicitGC:自动将System.gc() 调用转换成一个空操作,即应用中调用System.gc()
        会变成一个空操作,避免程序员在代码里进行System.gc()这种危险操作。System.gc()
        除非是到了万不得也的情况下使用,都应该交给 JVM。

    3.扩展方法

     (1)OOM(out of memory)内存溢出,内存不够用了。调整应用的内存占用,可能是代码有问题优化代码,Tomcat垃圾回收机制,调整Tomcat配置:-Xms、-Xmn、-Xmx ---- 其内存的配置需要根据服务器(或虚拟机)的实际内存来配置,优化最大工作数、队列数量。

     (2)Tomcat垃圾回收机制:垃圾回收机制会不定时的向堆内存中清理不可达(没有被程序引用)的对象。

     (3)finalize方法:java虚拟机在垃圾回收之前会先调用垃圾对象的finalize方法。(因为垃圾回收机制只负责回收内存,并不负责资源的回收,资源回收要由程序员完成)。

     (4)final方法:用于修饰类、成员变量和成员方法。final修饰的类不能被继承,其中所有的方法都不能被重写所以不能同时使用abstract(抽象类是用于被子类继承的和final起相反的作用)和final修饰类。

 

十、总结

  tomcat可以更好的作为动态服务器,为客户端提供服务,tomcat三大核心组件,web容器,jsp容器,servlet容器。功能组件有connector监听,container对内处理,四个子容器,engine,host,cpmtext,wrapper。

posted @ 2023-06-29 21:17  纸签  阅读(81)  评论(0编辑  收藏  举报