Tomcat原理与优化随笔
1. 基础组件:
Server,
Service:
Connector(http, https, ajp用于Apache反向代理), Engine
Engine:
Realm用于安全配置等,如UserDatabaseRealm
Host:Valve链,比如自带的AccessLogValve可以记录访问日志
DefaultServlet统一处理静态资源:
流程:doGet方法判断资源文件是否存在,文件是否可读,根据文件类型设置content-type,文件时间等写入输出流
JspServlet处理JSP请求:url-pattern = *.jsp或*.jspx
jsp编译过程:JspServlet判断JSP文件的Servelt是否生成/过期(如class文件修改时间和jsp文件修改时间不同, tomcat会创建一个新的classLoader加载相同jsp),
通过Compiler生成Servlet文件,调用该Servelt的_jspService方法,如果tomcat关闭了dev模式,则动态加载失效
HttpServletRequest:用到了门面模式
getParameter方法,判断参数是否解析过,如没有,则解析出参数键值对来,解析出的参数放到Map<String,List>结构中,这样每次
调用getParameter方法时,返回key的第一个value
Filter, FilterChain: 每个Filter完成后,调用FilterChain的doFilter方法调用下一个Filter
Connector: 根据配置的protocol不同使用不同的ProtocolHandler,请求完全由Handler处理,比如 Http11NioProtocol
Connector会将文件超过48k直接sendfile(channel.transferTo) 发送,而不会压缩,减少了CPU占用
Handler内部使用Endpoint进行请求接收处理
Executor:Connector可以配置使用的线程池
跨域请求:response.setHeader("Access-Control-Allow-Origin","*"); CorsFilter
Tomcat GC优化:根据应用的延迟和吞吐量特性选择合适的gc算法
ParallelGC吞吐量优先,不能满足低延迟需求
CMS:老年代回收与应用程序并行,实现低延迟(需要配置-XX:+UseParNewGC实现新生代并行回收,默认单线程),单核服务器需要配置好
应用线程和CMS收集线程所占cpu比例(交替运行垃圾收集器应用线程)。
-XX:+UseCMSCompactAtFullCollection 在Full GC的时候对年老代的压缩
-XX:+UseG1GC
-XX:+DisableExplicitGC: 不建议打开,Java NIO 堆外内存代码中有显式调用System.gc
ELParser: 解析EL表达式
类加载:
Webapp类加载器:先自己加载,在自己的类路径上找不到才会再委托parent(基础类不允许其重新加载,以及servlet-api也不允许重新加载)
不同的应用使用不同的WebappClassloader实例
如果是双亲委派没法实现多个web app隔离
应用启动的时候,会为其创建对应的WebappClassLoader
Common 类加载器:WebappClassloader的parent,所有应用共同可见的class
Tomcat原理与优化随笔的更多相关文章
- Tomcat 原理篇
TOMCAT 原理篇一.Tomcat 组成(Tomcat 由以下组件组成) 1.server a) Server是一个Catalina Servlet容器: b) Server 可以包含一个或多个se ...
- Tomcat 内存与优化篇
Tomcat 内存与优化一.Tomcat 运行环境介绍 1.Tomcat 本身无法直接在计算机上运行,需要依赖硬件基础上的操作系统和Java虚拟机: 2.Java 程序启动时JVM都会分配一个初始内存 ...
- Nginx与Tomcat/PHP架构优化的技术分享
PHP性能优化 一般我们是在/usr/local/php5/etc/php-fpm.conf这个文件里面进行相应的配置. 1) 如果设置成static,php-fpm进程数自始至终都是pm ...
- Tomcat配置与优化(内存、并发、管理)与性能监控
原文链接:http://blog.csdn.net/xyang81/article/details/51530979 一.JVM内存配置优化 在开发当中,当一个项目比较大时,依赖的jar包通常比较多, ...
- TOMCAT原理详解及请求过程(转载)
转自https://www.cnblogs.com/hggen/p/6264475.html TOMCAT原理详解及请求过程 Tomcat: Tomcat是一个JSP/Servlet容器.其作为Ser ...
- Java_冒泡排序_原理及优化
冒泡排序及其优化 一.原理及优化原理 1.原理讲解 冒泡排序即:第一个数与第二个数进行比较,如果满足条件位置不变,再把第二个数与第三个数进行比较.不满足条件则替换位置,再把第二个数与第三个数进行比较, ...
- 浅谈tomcat中间件的优化【转】
今天来总结一下tomcat的一些优化的方案,由于本人才疏学浅,写的不好,勿喷! tomcat对于大多数从事开发工作的童鞋应该不会很陌生,通常做为默认的开发环境来为大家服务,不过tomcat默认的一些配 ...
- Lucene底层原理和优化经验分享(1)-Lucene简介和索引原理
Lucene底层原理和优化经验分享(1)-Lucene简介和索引原理 2017年01月04日 08:52:12 阅读数:18366 基于Lucene检索引擎我们开发了自己的全文检索系统,承担起后台PB ...
- tomcat原理解析(一):一个简单的实现
tomcat原理解析(一):一个简单的实现 https://blog.csdn.net/qiangcai/article/details/60583330 2017年03月07日 09:54:27 逆 ...
随机推荐
- (6)autotools工具的使用
autotools是专门用来生成Makefile的一系列工具,包括autoscan.aclocal.autoheader.autoconf.automake等. (1)autotools ...
- 构建之法——homework1:问题思考
1.我看了第一章概论,1.2.4 软件工程的目标——创造“足够好”的软件,其中提到了什么是好的软件? 软件工程的一个要素就是把软件的Bug都消灭掉的过程. 提问:我们知道Bug是不可能完全消灭掉的, ...
- 前端基于VUE的v-charts的曲线显示
目录 前端基于VUE的v-charts的曲线显示 1. 应用背景 2. 分析数据生产者生成 3. 取出数据消费者 4. 前端显示 4.1 安装V-charts插件 4.2 引入veline曲线插件 4 ...
- .NET进阶篇-丑话先说,Flag先立--致青春
作为开发者,工作了半年,也总觉得技术栈和刚毕业区别不大,用的技术还都是N年前的,每每看到新东西,也只心里哇塞惊叹一下,然后就回归于忙碌.怪自己的技术池太浅,热门的令人称奇的技术也都是在其他巨人的肩膀上 ...
- Mac 安装node npm cnpm vue 以及卸载 node 和 npm 的方法 清空npm缓存的方法
S01 安装node(内含npm) 首先,到官网下载长期支持版,截止目前,最新的长期支持版本号是10.16.3 https://nodejs.org/zh-cn/download/ 下载完毕后,安装该 ...
- Java基础学习笔记(六) - 数据结构和集合
一.认识数据结构 1.数据结构有什么用? 合理的使用数据结构,可以更方便的查找存储数据. 2.常见的数据结构 数据存储常用结构有:栈.队列.数组.链表和红黑树. 栈:堆栈(stack),它是运算受限的 ...
- Java匹马行天下之教你用学汉语式方法学编程语言
Java匹马行天下之教你用学汉语式方法学编程语言 前言: 前段时间接连更新了带小白从入门到了解的几篇博客: <Java匹马行天下之编程常识知多少> <Java匹马行天下之走进编程的殿 ...
- React antd如何实现<Upload>组件上传附件再次上传已清除附件缓存问题。
最近在公司做React+antd的项目,遇到一个上传组件的问题,即上传附件成功后,文件展示处仍然还有之前上传附件的缓存信息,需要解决的问题是,要把上一次上传的附件缓存在上传成功或者取消后,可以进行清除 ...
- Cocos Creator一步一步实现重力球游戏
『 游戏玩法 』 通过手机陀螺仪,调整手机,让球从上一层的间隔中落到下一层,楼层会不断上涨,如果球碰到上方或者下方的火焰,游戏结束. 『 游戏预览 』 『 开发工具 』 1. CocosCreat ...
- Detours 劫持
在使用 Detours 劫持之前必须得拥有这两个东西:detours.h 和 detours.lib. 为了这两个东西我真的是弄了大半天,本着自己动手丰衣足食的思想: 我去 GitHub 克隆了一份来 ...