https://blog.csdn.net/swq463/article/details/86660034

Apache与Tomcat

两者定位:Apache是HTTP Web服务器,Tomcat是Web容器

容器(Containers)

容器通常理解就是装东西的,我们这里说 技术上的容器就是可以部署应用程序,并在上面运行的环境。

一般来说,它处理屏蔽了服务器平台的复杂性,使得应用程序在它的基础上可以方便快捷的部署;

对于应用程序来说,它就 是位于应用程序和平台之间的接口集合

容器管理组件的生命周期,向应用程序组件分派请求,并提供与上下文数据(如关于当前请求的信息)的接口。

Servlet的不同含义

  • Servlet(server applet)

属于Java EE重要技术规范,构建了"接收请求--调用servlet程序处理--返回响应"基本模型。

  • Servlet 程序(public class UserServlet extends httpServlet)

Java提供了开发Servlet程序的API,该API可以说Servlet容器的一部分,它对接应用程序与Servlet容器

  • Servlet 容器(Tomcat)

就是实现了Servlet技术规范的部署环境,它可以部署运行Servlet程序。提供了 Servlet (server applet)功能的服务器,叫做 Servlet 容器。

常见的servlet容器

Tomcat, Jetty, resin, Oracle Application server, WebLogic Server, Glassfish, Websphere, JBoss 等等。

对 web 程序来说,Servlet 容器的作用就相当于桌面程序里操作系统的作用,都是提供一些编程基础设施

在 Web 应用程序中,一个 Servlet 在一个时刻可能被多个用户同时访问。这时 Web 容器将为每个用户创建一个线程来执行 Servlet。如果 Servlet 不涉及共享资源的问题,不必关心多线程问题。但如果 Servlet 需要共享资源,需要保证 Servlet 是线程安全的。

Jetty和Tomcat的比较

性能比较:

单纯比较 Tomcat 与 Jetty 的性能意义不是很大,只能说在某种使用场景下,它表现的各有差异。因为它们面向的使用场景不尽相同。从架构上来看 Tomcat 在处理少数非常繁忙的连接上更有优势,也就是说连接的生命周期如果短的话,Tomcat 的总体性能更高。
而 Jetty 刚好相反,Jetty 可以同时处理大量连接而且可以长时间保持这些连接。例如像一些 web 聊天应用非常适合用 Jetty 做服务器,像淘宝的 web 旺旺就是用 Jetty 作为 Servlet 引擎
另外由于 Jetty 的架构非常简单,作为服务器它可以按需加载组件,这样不需要的组件可以去掉,这样无形可以减少服务器本身的内存开销,处理一次请求也是可以减少产生的临时对象,这样性能也会提高。另外 Jetty 默认使用的是 NIO 技术在处理 I/O 请求上更占优势,Tomcat 默认使用的是 BIO,在处理静态资源时,Tomcat 的性能不如 Jetty。

tomcat \ conf \ server.xml 文件详解

https://www.cnblogs.com/kismetv/p/7228274.html

  1. <?xml version="1.0" encoding="UTF-8"?>

  2. <!--

  3. Server元素在最顶层,代表整个Tomcat容器.因此它必须是server.xml中唯一一个最外层的元素

  4. port属性 表示Server接收shutdown指令的端口号,设为-1可以禁掉该端口

  5. shutdown属性 表示关闭Server的指令

  6. Server的主要任务就是:

  7. 提供一个接口让客户端能够访问到这个Service集合,

  8. 同时维护它所包含的所有的Service的声明周期,包括如何初始化、如何结束服务、如何找到客户端要访问的Service

  9. -->

  10. <Server port="8005" shutdown="SHUTDOWN">

  11. <Listener className="org.apache.catalina.startup.VersionLoggerListener" />

  12. <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />

  13. <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />

  14. <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />

  15. <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />

  16. <GlobalNamingResources>

  17. <Resource name="UserDatabase" auth="Container"

  18. type="org.apache.catalina.UserDatabase"

  19. description="User database that can be updated and saved"

  20. factory="org.apache.catalina.users.MemoryUserDatabaseFactory"

  21. pathname="conf/tomcat-users.xml" />

  22. </GlobalNamingResources>

  23. <!--

  24. 一个Server元素中可以有一个或多个Service元素

  25. Tomcat可以提供多个Service,不同的Service监听不同的端口

  26. 一个Service 代表 一个Engine元素 以及 一组与之相连的Connector元素

  27. -->

  28. <Service name="Catalina">

  29. <!--

  30. 一个Service可以包含多个Connector, 但是只能包含一个Engine, 其中

  31. Connector的作用是 从客户端接收请求, Engine的作用是 处理接收进来的请求,

  32. -->

  33. <!--Connector的主要功能:

  34. 接收连接请求,创建Request和Response对象用于和请求端交换数据;

  35. 然后 分配线程让Engine来处理这个请求,并把产生的Request和Response对象传给Engine

  36. 通过配置Connector,可以控制 请求Service的协议及端口号

  37. -->

  38. <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

  39. <!--

  40. AJP协议负责和其他的HTTP服务器(如Apache)建立连接: 在把Tomcat与其他HTTP服务器集成时,就需要用到这个连接器

  41. 之所以使用Tomcat和其他服务器集成,是因为Tomcat可以用作Servlet/JSP容器,但是对静态资源的处理速度较慢,不如Apache和IIS等HTTP服务器;

  42. 因此常常将Tomcat与Apache等集成,前者作Servlet容器,后者处理静态资源,而AJP协议便负责Tomcat和Apache的连接。

  43. -->

  44. <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

  45. <!--容器的功能是:

  46. 处理Connector接收进来的请求,并产生相应的响应。

  47. Engine、Host和Context都是容器,但它们不是平行的关系,而是父子关系:Engine包含Host,Host包含Context。

  48. 一个Engine组件可以处理Service中的所有请求,

  49. 一个Host组件可以处理发向一个特定虚拟主机的所有请求,

  50. 一个Context组件可以处理一个特定Web应用的所有请求。

  51. -->

  52. <!--

  53. name属性用于日志和错误信息,在整个Server中应该唯一

  54. defaultHost属性指定了默认的host名称,当发往本机的请求指定的host名称不存在时,一律使用defaultHost指定的host进行处理;

  55. 因此,defaultHost的值,必须与Engine中的一个Host组件的name属性值匹配。

  56. -->

  57. <Engine name="Catalina" defaultHost="localhost">

  58. <Realm className="org.apache.catalina.realm.LockOutRealm">

  59. <Realm className="org.apache.catalina.realm.UserDatabaseRealm" resourceName="UserDatabase"/>

  60. </Realm>

  61. <!-- Host是Engine的子容器:

  62. Engine组件中可以内嵌1个或多个Host组件,每个Host组件代表Engine中的一个虚拟主机。

  63. Host组件至少有一个,且其中一个的name必须与Engine组件的defaultHost属性相匹配。

  64. Host虚拟主机的作用,是运行多个Web应用(一个Context代表一个Web应用),并负责安装、展开、启动和结束每个Web应用。

  65. -->

  66. <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true">

  67. <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" pattern="%h %l %u %t &quot;%r&quot; %s %b" />

  68. </Host>

  69. </Engine>

  70. </Service>

  71. </Server>

tomcat 核心组件的关联

1、整体关系

核心组件之间的整体关系,在上一部分有所介绍,这里总结一下:

Server元素在最顶层,代表整个Tomcat容器;一个Server元素中可以有一个或多个Service元素。

Service在Connector和Engine外面包了一层,把它们组装在一起,对外提供服务。一个Service可以包含多个Connector,但是只能包含一个Engine;Connector接收请求,Engine处理请求。

Engine、Host和Context都是容器,且 Engine包含Host,Host包含Context。每个Host组件代表Engine中的一个虚拟主机;每个Context组件代表在特定Host上运行的一个Web应用。

2、如何确定请求由谁处理?

当请求被发送到Tomcat所在的主机时,如何确定最终哪个Web应用来处理该请求呢?

(1)根据协议和端口号选定Service和Engine

Service中的Connector组件可以接收特定端口的请求,因此,当Tomcat启动时,Service组件就会监听特定的端口。在第一部分的例子中,Catalina这个Service监听了8080端口(基于HTTP协议)和8009端口(基于AJP协议)。当请求进来时,Tomcat便可以根据协议和端口号选定处理请求的Service;Service一旦选定,Engine也就确定。

通过在Server中配置多个Service,可以实现通过不同的端口号来访问同一台机器上部署的不同应用。

(2)根据域名或IP地址选定Host

Service确定后,Tomcat在Service中寻找名称与域名/IP地址匹配的Host处理该请求。如果没有找到,则使用Engine中指定的defaultHost来处理该请求。在第一部分的例子中,由于只有一个Host(name属性为localhost),因此该Service/Engine的所有请求都交给该Host处理。

(3)根据URI选定Context/Web应用

这一点在Context一节有详细的说明:Tomcat根据应用的 path属性与URI的匹配程度来选择Web应用处理相应请求,这里不再赘述。

(4)举例

以请求http://localhost:8080/app1/index.html为例,首先通过协议和端口号(http和8080)选定Service;然后通过主机名(localhost)选定Host;然后通过uri(/app1/index.html)选定Web应用。

3、如何配置多个服务

通过在Server中配置多个Service服务,可以实现通过不同的端口号来访问同一台机器上部署的不同Web应用。

在server.xml中配置多服务的方法非常简单,分为以下几步:

(1)复制<Service>元素,放在当前<Service>后面。

(2)修改端口号:根据需要监听的端口号修改<Connector>元素的port属性;必须确保该端口没有被其他进程占用,否则Tomcat启动时会报错,而无法通过该端口访问Web应用。

以Win7为例,可以用如下方法找出某个端口是否被其他进程占用:netstat -aon|findstr "8081"发现8081端口被PID为2064的进程占用,tasklist |findstr "2064"发现该进程为FrameworkService.exe(这是McAfee杀毒软件的进程)。

(3)修改Service和Engine的name属性

(4)修改Host的appBase属性(如webapps2)

(5)Web应用仍然使用自动部署

(6)将要部署的Web应用(WAR包或应用目录)拷贝到新的appBase下。

以第一部分的server.xml为例,多个Service的配置如下:

<?xml version='1.0' encoding='utf-8'?>
<Server port="8005" shutdown="SHUTDOWN"><Listener className="org.apache.catalina.startup.VersionLoggerListener" /><Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /><Listener className="org.apache.catalina.core.JasperListener" /><Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /><Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /><Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" /><GlobalNamingResources><Resource name="UserDatabase" auth="Container" type="org.apache.catalina.UserDatabase" description="User database that can be updated and saved" factory="org.apache.catalina.users.MemoryUserDatabaseFactory" pathname="conf/tomcat-users.xml" /></GlobalNamingResources><Service name="Catalina"><Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /><Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /><Engine name="Catalina" defaultHost="localhost"><Realm className="org.apache.catalina.realm.LockOutRealm"><Realm className="org.apache.catalina.realm.UserDatabaseRealm"resourceName="UserDatabase"/></Realm><Host name="localhost"  appBase="/opt/project/webapps" unpackWARs="true" autoDeploy="true"><Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log." suffix=".txt" pattern="%h %l %u %t &quot;%r&quot; %s %b" /></Host></Engine></Service><Service name="Catalina2"><Connector port="8084" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /><Connector port="8010" protocol="AJP/1.3" redirectPort="8443" /><Engine name="Catalina2" defaultHost="localhost"><Realm className="org.apache.catalina.realm.LockOutRealm"><Realm className="org.apache.catalina.realm.UserDatabaseRealm"resourceName="UserDatabase"/></Realm><Host name="localhost"  appBase="/opt/project/webapps2" unpackWARs="true" autoDeploy="true"><Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log." suffix=".txt" pattern="%h %l %u %t &quot;%r&quot; %s %b" /></Host></Engine></Service>
</Server>

再将原webapps下的docs目录拷贝到webapps2中,则通过如下两个接口都可以访问docs应用:

http://localhost:8080/docs/

http://localhost:8084/docs/

Tomcat配置两个应用服务相关推荐

  1. 同时安装两个Tomcat配置教程(Win10)

    转载注明出处 https://blog.csdn.net/zouguo1211/article/details/83997231 前言 在日常开发中,有时候一个Tomcat容器不能满足我们的需求,那么 ...

  2. 详解Tomcat配置JVM参数步骤

    这里向大家描述一下如何使用Tomcat配置JVM参数,Tomcat本身不能直接在计算机上运行,需要依赖于硬件基础之上的操作系统和一个java虚拟机.您可以选择自己的需要选择不同的操作系统和对应的JDK ...

  3. Springboot内置Tomcat配置参数调优

    Springboot内置Tomcat配置参数调优,首先,线程数是一个重点,每一次HTTP请求到达Web服务器,Web服务器都会创建一个线程来处理该请求,该参数决定了应用服务同时可以处理多少个HTTP请 ...

  4. Tomcat 配置 项目 到tomcat目录外面 和 域名绑定访问(api接口、前端网站、后台管理网站)...

    先停止tomcat服务 1.进入apache-tomcat-7.0.68/conf/Catalina/localhost(如果之前还都没有启动过tomcat,是不会有此目录的,先启动一次再关闭,会自动 ...

  5. Rainbond最佳实践:Tomcat配置Redis实现Session共享

    Rainbond:生产级无服务器PaaS Rainbond是国内首个开源的生产级无服务器PaaS,深度整合基于Kubernetes的容器管理.多类型CI/CD应用构建与交付.多数据中心的资源管理等技术 ...

  6. intellij tomcat配置

    目录 intellij tomcat配置 @(目录) intellij tomcat配置 如上图标注 1 所示,我们可以切换随时为项目切换不同的容器. 如上图标注 2 所示,我们可以指定给运行的容器设 ...

  7. Nginx+tomcat配置集群

    2019独角兽企业重金招聘Python工程师标准>>> 开发的应用采用F5负载均衡交换机,F5将请求转发给5台hp unix服务器,每台服务器有多个webserver实例,对外提供w ...

  8. 图文解说:Nginx+tomcat配置集群负载均衡

    图文解说:Nginx+tomcat配置集群负载均衡 博客分类: appserver nginxTomcatUbuntuLinux网络应用  作者:niumd Blog:http://ari.iteye ...

  9. 多个tomcat配置

    在centos7.3下搭建jenkins自动部署环境,需要一个tomcat来启动jenkins,另一个用来自动部署的位置,因此需要两个tomcat同时运行,并且在自动构建后能够启动项目,又不会关闭je ...

  10. Nginx+memcached+tomcat配置集群session共享负载均衡

    Nginx+memcached+tomcat配置集群session共享负载均衡 配置环境: windows xp下 jdk1.7.0_10      nginx-1.2.6  (附下载)      m ...

最新文章

  1. 敏捷开发日常跟进系列之二:燃尽图(中)
  2. 新书 5 折腰斩!畅销技术类图书推荐
  3. iOS: 转载CoreData数据库框架
  4. 计算机在能源领域的应用,计算机在能源中的应用
  5. 从入门到放弃之大数据Hive
  6. LaTeX中添加\usepackage{subfigure}一直报错的解决办法,亲测
  7. Dubbo源码分析系列-Dubbo的动态编译原理
  8. html语言中强调的ddr,DDR基础知识
  9. 计算机视觉(CV)中HOG算法的主要步骤
  10. 宝骏530中控屏怎么安装软件_【中山永豊】宝骏530音响升级美国DD双低音,炸机效果征服全场观众!...
  11. Git 使用篇二:搭建远程服务器
  12. Flutter高级第2篇:JSON的序列化和反序列化、创建模型类转换Json数据
  13. 20155201 2016-2017-2 《Java程序设计》第五周学习总结
  14. node 多进程 vs java_多进程 VS 多线程 VS 线程池 VS EventLoop
  15. matlab的小波分析,matlab小波分析步骤是什么 - 全文
  16. python远程连接windows_python winrm 连接windows
  17. 搜狗浏览器怎么清除浏览记录 搜狗浏览器清除浏览记录教程
  18. 大漠插件问题:解决win10win7win8系统找不到指定的模块,注册不了大漠插件的问题
  19. Cell Biolabs丨艾美捷丨羟脯氨酸检测试剂盒
  20. 【引语收集计划】《启迪》 本雅明--导言-瓦尔特.本雅明 : 1892-1940 by汉娜.阿伦特

热门文章

  1. fastjson转换对象时出错,$ref: $.data.list[0].xxxx
  2. 网络中各层协议(7层)
  3. 自己实现LinkedList类
  4. js-权威指南学习笔记21
  5. 【存档】20个正则表达式
  6. win10升级后ctrl+shift+f失效了(zend studio)问题解决
  7. 复杂作业车间调度-单机调度问题研究
  8. 【keras】数据增强之---ImageDataGenerator
  9. Radar altimeters and laser altimeters
  10. 基于ENVI/IDL实现国产卫星影像批处理功能