tomcat打开endpoint的监听对通过某种协议,通常下是http的信息进行解析,组装成request,接着给Http11Protocol(ProtocolHandler)和Http11Processor处理。
adapter.service(request, response);
connector.getService().getContainer().getPipeline().getFirst().invoke(request, response);
最终选择具体的Valve类处理request并生成response。
Valve和Pipeline的关系:Pipeline是valve的链表,表头是first,表尾是basic,具体的实现是StandardPipeline。
valve的实现是ValveBase及其子类。
先看ValveBase的定义
public abstract class ValveBase extends LifecycleMBeanBase
implements Contained, Valve {
//------------------------------------------------------ Constructor
public ValveBase() {
this(false);
}
public ValveBase(boolean asyncSupported) {
this.asyncSupported = asyncSupported;
}
........
/**
* The next Valve in the pipeline this Valve is a component of.
*/
protected Valve next = null;
next就如同C和C++数据结构描述的指针,形如
struct valve{
valve * next
};
StandardPipeline的具体实现
public class StandardPipeline extends LifecycleBase
implements Pipeline, Contained {
...............................
/**
* The basic Valve (if any) associated with this Pipeline.
*/
protected Valve basic = null;
/**
* The first valve associated with this Pipeline.
*/
protected Valve first = null;
StandardPipeline设置了两个哨兵,一个basic,一个是first。对链表的操作增加删除等,对哨兵有特殊处理的。
看个add的例子
public void addValve(Valve valve) {
// Validate that we can add this Valve
if (valve instanceof Contained)
((Contained) valve).setContainer(this.container);
// Start the new component if necessary
if (getState().isAvailable()) {
if (valve instanceof Lifecycle) {
try {
((Lifecycle) valve).start();
} catch (LifecycleException e) {
log.error("StandardPipeline.addValve: start: ", e);
}
}
}
// Add this Valve to the set associated with this Pipeline
if (first == null) {
first = valve;
valve.setNext(basic);
} else {
Valve current = first;
while (current != null) {
if (current.getNext() == basic) {
current.setNext(valve);
valve.setNext(basic);
break;
}
current = current.getNext();
}
}
container.fireContainerEvent(Container.ADD_VALVE_EVENT, valve);
}
add一个元素是加在basic之前,处理pipeline的时候,是先取出first。
所以如果first==null,表面还没有pipeline种还没有元素,此时就先设置first。
不然,先找到basic以前的位置,将新的valve插入在basic之前,进行排队。
验证下可以看下面的remove操作
public void removeValve(Valve valve) {
Valve current;
if(first == valve) {
first = first.getNext();
current = null;
} else {
current = first;
}
while (current != null) {
if (current.getNext() == valve) {
current.setNext(valve.getNext());
break;
}
current = current.getNext();
}
if (first == basic) first = null;
if (valve instanceof Contained)
((Contained) valve).setContainer(null);
// Stop this valve if necessary
if (getState().isAvailable()) {
if (valve instanceof Lifecycle) {
try {
((Lifecycle) valve).stop();
} catch (LifecycleException e) {
log.error("StandardPipeline.removeValve: stop: ", e);
}
}
}
try {
((Lifecycle) valve).destroy();
} catch (LifecycleException e) {
log.error("StandardPipeline.removeValve: destroy: ", e);
}
container.fireContainerEvent(Container.REMOVE_VALVE_EVENT, valve);
}
分享到:
相关推荐
哈希表--链表 哈希表--链表 哈希表--链表 哈希表--链表哈希表--链表 哈希表--链表哈希表--链表 哈希表--链表哈希表--链表 哈希表--链表哈希表--链表 哈希表--链表
57春节7天练---Day-1:数组和链表 数组和链表.pdf
数据结构--数组、单链表和双链表介绍以及双向链表 数组和链表.pdf
Linux运维-嵌入式物联网开发教程-获取链表结点个数和链表释放函数.mp4
python算法-数组和链表 数组和链表.pdf
uC/OS-II学习笔记—空闲链表和就绪链表
3-软件课程设计补充知识-数组和链表 数组和链表.ppt
C语言程序设计-职工信息管理系统(链表).docxC语言程序设计-职工信息管理系统(链表).docxC语言程序设计-职工信息管理系统(链表).docxC语言程序设计-职工信息管理系统(链表).docxC语言程序设计-职工信息管理系统(链表)...
采用数组标记方式实现,将绘图与逻辑实现独立。CSnake为标准C++代码,可单独提取出来对界面进行更换。
链表逆序链表逆序链表逆序链表逆序链表逆序链表逆序链表逆序链表逆序链表逆序链表逆序链表逆序链表逆序
Linux内核2.6.14源码分析-双向循环链表代码分析(巨详细)
双链表-循环链表-静态链表.pdf
链表源码,链表源码,链表源码,链表源码,链表源码
链表构造
02-第2章线性表第7讲-双向链表和双向循环链表.pdf
Java单链表源码分析ds-算法 在 - 获取有关数据结构和算法的完整免费课程。 订阅频道以获取所有免费课程 - :folded_hands: 感谢您一直以来的厚爱和支持。 我虚心地请求您帮助这个频道发展更多,为此请点赞、分享和...
java数组和链表底层-链表的底层原理和实现 数组和链表.pdf
004-FreeRTOS202212-4005-将节点插入到链表的尾部
嵌入式学习-02-数据结构和算法 (链表)