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虚拟机配置
(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。