servlet运作机制
最近研究zipkin,在研究客户端brave的时候,才算开始理解servlet了。
servlet只是tomcat被实例化一次;
之后每次访问其实都是对同一个servlet示例操作;所以,不要在servlet的实现中创建什么全局变量(实例变量),并发可能会有问题。
通过下面的示例可以测试出只是被实例化一次(这里的全局遍量是为了测试使用)。
public class Test extends HttpServlet {
private static int count = 0;
private int num = 0;
public Test() {
super();
count ++;
System.out.println("实例化了 "+count+" 次");
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
num ++;
System.out.println("被访问了" + num+"次");
}
}
切换浏览器能够看到servlet只是被实例化一次。
servlet以及filter的定义是在web.xml里面定义的;那么到底什么是servlet?servlet其实是对于客户端请求(HttpRequest)的处理;处理继续细化就是要对处理进行分类处理;在spring的时候我们早已经把处理分配到了各个controller里面去做;web项目,servlet和controller之间的关系是1:m:n;于是我们看到在web.xml里面定义spring的类就是dispatcher你就知道:
<servlet>
<servlet-name>spring-webmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
web容器(比如tomcat)是servlet的容器;因为一个tomcat里面可以跑多个web项目,所以可以放置多个servlet;尽管只有一个servlet,但是web容器里面却有着N多线程来同时跑(N是可以配置的),所以一个servlet其实是有多个线程来跑;客户端发来一个请求,其实是由线程池里面选择一个线程来调用serlvet的service函数来进行处理;所以,对于servlet实现类里面的实例变量(全局变量)慎用。
但是其实一个web项目也是可以指定多个servlet的(大多数情况下只需要一个servlet),这些都是在web.xml中配置的;有servlet节点,和servlet-mapping节点,后者就是用来定义指定的哪些url pattern映射到哪个servlet上面。
除此之外,就是listener节点,可以监听Servet的各个生命周期的各个事件,从ContextListener可以监听Context的创建和销毁到SessionListener,可以监听Session的创建和销毁,到SessionAttributeListener可以监听Session的属性值的变化等等,可以进行非常细粒度的(生命周期)事件的监听。
Context这个对象要注意一下,一个web工程只对应一个Context,这个环境里面封装了web工程的对象以及运行环境,session,servlet,engine等都在他的管理之下。我们在tomcat中配置web工程的时候也是配置context节点。
参考:
https://blog.csdn.net/kingxueyuf/article/details/8109651
https://www.cnblogs.com/binyue/p/4513577.html
https://www.ibm.com/developerworks/cn/java/j-lo-servlet/
https://www.ibm.com/developerworks/cn/education/java/j-intserv/j-intserv.html
《深入分析Java Web技术内幕》
servlet运作机制的更多相关文章
- AsyncLocal的运作机制和陷阱
这是今天帮柠檬分析一个AsyncLocal相关的问题时发现的. 试想这个代码输出的值是多少? using System; using System.Threading; using System.Th ...
- servlet运行机制、Request内置对象和服务器端跳转
servlet运行机制: 当发送一个请求到服务器的时候,容器(Tomcat)会判断该路径属于哪一个 Servlet 进行处理,Servlet 有一个抽象父类“HttpServlet”,这个类是一个模板 ...
- JavaWeb之servlet管理机制
一.什么是Servlet 简单的说,浏览器发出请求到tocat服务器,服务器就会初始化一个servlet实例(servlet采取生命托管的方式实现单例,不存在时才会创建实例),servlet示例会启动 ...
- 【SpringCloud技术专题】「Eureka源码分析」从源码层面让你认识Eureka工作流程和运作机制(上)
前言介绍 了解到了SpringCloud,大家都应该知道注册中心,而对于我们从过去到现在,SpringCloud中用的最多的注册中心就是Eureka了,所以深入Eureka的原理和源码,接下来我们要进 ...
- Hadoop-Yarn-框架原理及运作机制(原理篇)
文件为转载:http://blog.csdn.net/liuwenbo0920/article/details/43304243 一.YARN基本架构 YARN是Hadoop 2.0中的资源管理系统, ...
- Hadoop-Yarn-框架原理及运作机制
一.YARN基本架构 YARN是Hadoop 2.0中的资源管理系统,它的基本设计思想是将MRv1中的JobTracker拆分成了两个独立的服务:一个全局的资源管理器ResourceManager和每 ...
- Hadoop Yarn 框架原理及运作机制及与MapReduce比较
Hadoop 和 MRv1 简单介绍 Hadoop 集群可从单一节点(其中所有 Hadoop 实体都在同一个节点上运行)扩展到数千个节点(其中的功能分散在各个节点之间,以增加并行处理活动).图 1 演 ...
- redis底层设计(五)——内部运作机制
5.1 数据库 5.1.1 数据库的结构: Redis 中的每个数据库,都由一个redis.h/redisDb 结构表示: typedef struct redisDb { // 保存着数据库以整数表 ...
- Redis的内部运作机制
本文将分五个部分来分析和总结Redis的内部机制,分别是:Redis数据库.Redis客户端.Redis事件.Redis服务器的初始化步骤.Redis命令的执行过程. 首先介绍一下Redis服务器的状 ...
随机推荐
- SpringBoot自动配置的实现原理
之前一直在用SpringBoot框架,一直感觉SpringBoot框架自动配置的功能很强大,但是并没有明白它是怎么实现自动配置的,现在有空研究了一下,大概明白了SpringBoot框架是怎么实现自动配 ...
- MyBatis的返回参数类型
MyBatis的返回参数类型分两种 1. 对应的分类为: 1.1.resultMap: 1.2.resultType: 2 .对应返回值类型: 2.1.resultMap:结果集 2.2.result ...
- yii2手动添加图片处理插件Imagine
1.首先从官网下载yii2-imagine的拓展 下载地址:https://github.com/yiisoft/yii2-imagine 下载包名称:yii2-imagine-master 2.然后 ...
- IOS-CALayer(图层)
BWLayer.m // // BWLayer.m // IOS_0222_CALayer // // Created by ma c on 16/2/23. // Copyright © 2016年 ...
- 2793 [Poi2012]Vouchers
我们直接模拟就可以了= = now[x]表示x的倍数已经取到x * i了,于是每次读入x,直接向上枚举x个没取过的数即可. /************************************* ...
- windows下gvim搭建IDE
原文转载自:手把手教你把Vim改装成一个IDE编程环境(图文) 如侵犯您的版权,请联系:windeal12@qq.com By: 吴垠 Date: 2007-09-07 Version: 0.5 Em ...
- 20165202 week4课下补做
1.相关知识点的总结 编程实现1!+2!+3!+... + N!的功能,N由命令行传入,比如类名为SumofRecur, java SumofRecur 8 给出1!+2!+3!+... + 8!的值 ...
- android 城市选择
我们在开发过程中兰冕会有选着城市地点等东西,这些都是常用的东西,所以我也就将他封装起来了先来看看效果吧 1.首先看下项目的结构: 2.看下整体的项目效果 三:主ativity private Cont ...
- 深度学习(六十九)darknet 实现实验 Compressing Deep Neural Networks with Pruning, Trained Quantization and Huffma
本文主要实验文献文献<Deep Compression: Compressing Deep Neural Networks with Pruning, Trained Quantization ...
- js 由快到慢的执行
let t=0; for(var i=0;i<len;i++){ (function (t) { $timeout(function(){ console.log(t); },t); })(t) ...