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服务器的状 ...
随机推荐
- js中删除数组中某一项的方法
1:js中的splice方法 splice(index,len,[item]) 注释:该方法会改变原始数组. splice有3个参数,它也可以用来替换/删除/添加数组内某一个或者几个值 inde ...
- Sum All Numbers in a Range
我们会传递给你一个包含两个数字的数组.返回这两个数字和它们之间所有数字的和. 最小的数字并非总在最前面. 这是一些对你有帮助的资源: Math.max() Math.min() Array.reduc ...
- jps、jstack、jmap、jhat、jstat、hprof使用详解
https://my.oschina.net/feichexia/blog/196575#comment-list A. jps(Java Virtual Machine Process Status ...
- log4cpp安装
body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...
- shell脚本中四则运算
方法一: (()) ##在括号里面可以直接对变量进行操作 例如:vim test.sh 方法二: let ##let后面加要操作的运算 例如: 方法三: expr ...
- make笔记
Makefile基本格式如下: target ... : prerequisites ... command ... ... 其中, target - 目标文件, 可以是 Object File, 也 ...
- Linux:declare命令详解
declare declare命令用于声明和显示已存在的shell变量.当不提供变量名参数时显示所有shell变量.declare命令若不带任何参数选项,则会显示所有shell变量及其值.declar ...
- TF随笔-8
#!/usr/bin/env python2 # -*- coding: utf-8 -*- """ Created on Mon Jul 10 09:35:04 201 ...
- python学习之多线程(二)
使用multiprocessing 使用multiprocessing.dummy 单使用multiprocessing模块的指的是多进程,使用multiprocessing.dummy则表示使用的是 ...
- iOS常识名词解释 2016/04/05
Bundle : http://www.cnblogs.com/BigPolarBear/archive/2012/03/28/2421802.html http://blog.sina.com.cn ...