zoukankan      html  css  js  c++  java
  • Tomcat的工作模式&运行模式

    Tomcat的工作模式&运行模式

     

    1、三种工作模式

    Tomcat作为servlet容器,有三种工作模式:

    1、独立的servlet容器,servlet容器是web服务器的一部分;

    2、进程内的servlet容器,servlet容器是作为web服务器的插件和java容器的实现,web服务器插件在内部地址空间打开一个jvm使得java容器在内部得以运行。反应速度快但伸缩性不足;

    3、进程外的servlet容器,servlet容器运行于web服务器之外的地址空间,并作为web服务器的插件和java容器实现的结合。反应时间不如进程内但伸缩性和稳定性比进程内优;

    进入Tomcat的请求可以根据Tomcat的工作模式分为如下两类:

    Tomcat作为应用程序服务器:请求来自于前端的web服务器,这可能是Apache, IIS, Nginx等;

    Tomcat作为独立服务器:请求来自于web浏览器;

    2、三种运行模式

    常见于server.xml中的连接器类型通常有4种:

      1)HTTP连接器

      2)SSL连接器

      3)AJP 1.3连接器

      4)proxy连接器

    Tomcat Connector(连接器)有三种运行模式:

      1)bio(blocking I/O)
      即阻塞式I/O操作,表示Tomcat使用的是传统的Java I/O操作(即java.io包及其子包)。是基于JAVA的HTTP/1.1连接器,Tomcat7以下版本在默认情况下是以bio模式运行的。一般而言,bio模式是三种运行模式中性能最低的一种。我们可以通过Tomcat Manager来查看服务器的当前状态。(Tomcat7 或以下,在 Linux 系统中默认使用这种方式)

      一个线程处理一个请求,缺点:并发量高时,线程数较多,浪费资源

    server.xml 文件中的配置 (端口号自己设定,只要不占用就行)

    <Connector port="9090" protocol="HTTP/1.1" connectionTimeout="20000"  redirectPort="8443" />

      2)nio(new I/O)
      nio是Java SE 1.4及后续版本提供的一种新的I/O操作方式(即java.nio包及其子包)。

      Java nio是一个基于缓冲区、并能提供非阻塞I/O操作的Java API,因此nio也被看成是non-blocking I/O的缩写。它拥有比传统I/O操作(bio)更好的并发运行性能。

      要让Tomcat以nio模式来运行只需要在Tomcat安装目录/conf/server.xml 中将对应的中protocol的属性值改为 org.apache.coyote.http11.Http11NioProtocol即可

      利用 Java 的异步请求 IO 处理,可以通过少量的线程处理大量的请求

      注意: Tomcat8 以上版本在 Linux 系统中,默认使用的就是NIO模式,不需要额外修改 ,Tomcat7必须修改Connector配置来启动

    server.xml 文件中的配置

    <Connector port="9090"  protocol="org.apache.coyote.http11.Http11NioProtocol" connectionTimeout="20000" redirectPort="8443" />

      3)apr(Apache Portable Runtime/Apache可移植运行时)

      Tomcat将以JNI的形式调用Apache HTTP服务器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高Tomcat对静态文件的处理性能。Tomcat apr也是在Tomcat上运行高并发应用的首选模式。从操作系统级别来解决异步的IO问题

      APR是使用原生C语言编写的非堵塞I/O,利用了操作系统的网络连接功能,速度很快。 

      但是需先安装apr和native,若直接启动就支持apr,能大幅度提升性能,不亚于魔兽开局爆高科技兵种,威力强大.

    server.xml 文件中的配置

    <Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol"
    URIEncoding="UTF-8"
    maxConnections="10000"
    maxThreads="2000"
    acceptCount="2000"
    minSpareThreads="100"
    compression="on"
    compressionMinSize="2048"
    compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
    enableLookups="false"
    disableUploadTimeout="true"
    connectionTimeout="20000"
    redirectPort="8443" />

    配置之前首先安装APR以及与 Tomcat-native 整合。

    安装直通车:

    https://blog.csdn.net/strivenoend/article/details/79178385?ops_request_misc=&request_id=&biz_id=102&utm_term=Tomcat%25203%25E7%25A7%258D%25E5%25B7%25A5%25E4%25BD%259C%25E6%25A8%25A1%25E5%25BC%258F&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduweb~default-1-79178385.first_rank_v2_pc_rank_v29

  • 相关阅读:
    【POJ 3525】Most Distant Point from the Sea(直线平移、半平面交)
    【HDU 4940】Destroy Transportation system(无源无汇带上下界可行流)
    codevs 5962 [SDOI2017]数字表格
    【NOIP2016】天天爱跑步
    [2011WorldFinal]Chips Challenge[流量平衡]
    [Ahoi2014]支线剧情[无源汇有下界最小费用可行流]
    [NOI2008] 志愿者招募[流量平衡]
    [Wc2007]剪刀石头布[补集转化+拆边]
    poj3281 Dining[最大流]
    1458: 士兵占领[最大流]
  • 原文地址:https://www.cnblogs.com/bors/p/tomcat1.html
Copyright © 2011-2022 走看看