Tomcat篇

Tomcat是什么

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

Tomcat的目录结构

  • /bin:存放用于启动和暂停Tomcat的脚本
  • /conf:存放Tomcat的配置文件
  • /lib:存放Tomcat服务器需要的各种jar包
  • /logs:存放Tomcat的日志文件
  • /temp:Tomcat运行时用于存放临时文件
  • /webapps:web应用的发布目录
  • /work:Tomcat把有jsp生成Servlet放于此目录下

tomcat 如何优化

改Tomcat最大线程连接数

需要修改conf/server.xml文件,修改里面的配置文件:

maxThreads="150"  //Tomcat使用线程来处理接收的每个请求。

这个值表示Tomcat可创建的最大的线程数。默认值200。可以根据机器的时期性能和内存大小调整,一般可以在400-500,最大可以在800左右。

修改Tomcat的运行模式

  • BIO,在tomcat8以下,默认使用BIO模式,对于每一个请求都要创建一个线程来进行处理,不适合高并发。
  • NIO,tomcat8以上的版本,默认使用NIO
  • APR,全称 Apache Portable Runtime,是Tomcat生产环境运行的首选方式,如果操作系统未安装 APR 或者 APR 路径未指到 Tomcat 默认可识别的路径,则 APR 模式无法启动,自动切换启动 NIO 模式。所以必须要安装 APR 和 Native,直接启动就支持 APR,APR是从操作系统级别解决异步 IO 问题,APR 的本质就是使用 JNI 技术调用操作系统底层的 IO 接口,所以需要提前安装所需要的依赖提升 Tomcat 对静态文件的处理性能,当然也可以采用动静分离。

Tomcat内存优化,启动时告诉JVM我要多大内存

调优方式的话,修改:

  • Windows 下的catalina.bat
  • Linux 下的catalina.sh

修改方式如:JAVA_OPTS="-Xms256m -Xmx512m" -Xms JVM初始化堆的大小-Xmx JVM堆的最大值 实际参数大

tomcat 有哪几种Connector 运行模式(优化)

Tomcat Connector的三种运行模式。

BIO:同步并阻塞 

一个线程处理一个请求。缺点:并发量高时,线程数较多,浪费资源。Tomcat7或以下,在Linux系统中默认使用这种方式。 配置项:protocol=”HTTP/1.1”

NIO:同步非阻塞IO 

利用Java的异步IO处理,可以通过少量的线程处理大量的请求,可以复用同一个线程处理多个connection(多路复用)。

Tomcat8在Linux系统中默认使用这种方式。 Tomcat7必须修改Connector配置来启动。 配置项:protocol="org.apache.coyote.http11.Http11NioProtocol"

说明:我们常用的Jetty,Mina,ZooKeeper等都是基于java nio实现。

APR:即Apache Portable Runtime,从操作系统层面解决io阻塞问题

AIO方式,异步非阻塞IO(Java NIO2又叫AIO) 主要与NIO的区别主要是操作系统的底层区别.可以做个比喻:比作快递,NIO就是网购后要自己到官网查下快递是否已经到了(可能是多次),然后自己去取快递;AIO就是快递员送货上门了(不用关注快递进度)。

配置项:protocol="org.apache.coyote.http11.Http11AprProtocol"

说明:需在本地服务器安装APR库。Tomcat7或Tomcat8在Win7或以上的系统中启动默认使用这种方式。Linux如果安装了apr和native,Tomcat直接启动就支持apr。

 

posted @ 2021-12-22 23:21  残城碎梦  阅读(46)  评论(0编辑  收藏  举报