设为首页 收藏本站
查看: 1152|回复: 0

[经验分享] [笔记]深入剖析Tomcat-tomcat的默认连接器,servlet容器

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-8-8 13:25:14 | 显示全部楼层 |阅读模式
  连接器
  实现Connector接口
  HttpConnector实例维护一个HttpProcessor实例池,个数有minProcessors和maxProcessors决定,如果HttpProcessor实例的数目达到max,则http请求则会被忽略。
DSC0000.png
DSC0001.png




public final class Bootstrap(){
public static void main(String[] args){
HttpConnector httpConnector = new HttpConnector();
SimpleContainer container = new SimpleContainer();
httpConnector.setContainer(container);
connector.initialize();
connector.start();
}
}
public class HttpConnector implements Connector, Runable{
protected int minProcessors = 5;
private int maxProcessors = 20;
private Stack processors = new Stack();
public void start{
while (curProcessors < minProcessors){
if (maxProcessors>0 && curProcessors >= maxProcessors)
break;
HttpProcessor httpProcessor = new HttpProcessor();
recycle(httpProcessor);
}
}
public void run(){
while(!loop){
//...省略
ServerSocket serverSocket = new(...)
Socket socket = setverSocket.accept();
HttpProcessor httpProcessor = createHttpProcessor(this); //从processor池中读取,如果无且小于max,则创建
if (httpProcessor==null) //processor池中无实例
                socket.close();
httpProcessor.assign(socket);
}
}
public void recycle(HttpProcessor httpProcessor){
processors.push(httpProcessor);//入栈
    }
}
public class SimpleContainer implements Container{
//...
public void invoke(Request request, Response response){
URL[] urls = new URL(1);
//...url 处理
String servletName = null;
//...servletName处理
URLClassLoader loader = new URLClassLoader(urls);
Class class = loader.loadClass(servletName);
Servlet servlet = class.newInstance();
servlet.service((HttpServletRequest)request, (HttpServletResponse)response);
}
}
public class HttpProcessor implements Runable{
public void run(){
while(!loop){
Socket socket = await();
if (socket == null){
continue;
}
//...
            process(socket);
connector.recycle(this);
synchronized (threadSync){
threadSync.notifyAll();
}
}
}
private synchronized void assign(Socket socket){
while (available){
wait();
}
//...
this.socket = socket;
available = true;
notifyAll(); //唤醒await处理
    }
private synchronized Socket await(){
while (!available){
wait();
}
Socket socket = this.scoket;
available = false;
notifyAll(); //告诉assign,处理完成,可以接收下一个
return socket;
}
public void process(Socket socket){
//parse request header parameters and so on..., response
//process, call container.invoke
    }
}
  
  servlet容器
  context应用程序



public final class Bootstrap{
public static void main(String[] args){
HttpConnector httpConnector = new HttpConnector();
Wrapper wrapper1 = new SimpleWrapper();//实际处理servlet,context子容器
wrapper1.setName("wrapper1");
wrapper1.setServletClass("ClientServlet1");
Wrapper wrapper2 = new SimpleWrapper();
wrapper2.setName("wrapper2");
wrapper2.setServletClass("ClientServlet2");
Context context = new SimpleContext(); //与连接器相关联的主容器
        context.addChild(wrapper1);
context.addChild(wrapper2);
Valve valve1 = new HeaderLoggerValve(); //与容器相关联
Valve valve2 = new ClientIPLoggerValve();
((Pipeline)context).addValve(valve1);
((Pipeline)context).addValve(valve2);
Mapper mapper = new SimpleContextMapper(); //映射器
mapper.setProtocol("http");
context.addMapper(mapper);
Loader loader = new SimpleLoader();
context.setLoader(loader);
context.addServletMapping("/Primitive", "wrapper1");
context.addServletMapping("/Moder", "wrapper2");
httpConnector.initialize();
httpConnector.start();
}
}
//     1.调用context的invoke
public class SimpleContext implements Context, Container{
// addServletMapping
//findServletMapping
//addMapper
//map();返回负责处理当前的wrapper实例
public void invoke(Request request, Response response){
pipeline.invoke(request, response); //   
    }
}
//      2.调用管道invoke方法
public class SimplePipeline {
public class SimplePipelineValveContext implements ValveContext{
//invokeNext
    }
public void invoke(Request request, Response response){
(new SimplePipelineValveContext()).invokeNext(request, response); //会调用添加到context实例中的阀,调用基础阀SimpleContextValve的invoke方法,
    }
}
//     4.调用基础阀invoke
public class SimpleContextValve implements valve{
public void invoke(Request request, Response response){
Wrapper wrapper = context.map(request, true); //使用context的映射器查找wrapper
wrapper.invoke(request, response);//再调用invoke方法
    }
}
//    子容器基础阀invoke
public class SimpleWraperValve implements valve{
public void invoke(Request request, Response response){
Wrapper wrapper = context.map(request, true); //使用context的映射器查找wrapper
wrapper.invoke(request, response);//再调用invoke方法
}
}
//        5.调用子容器的invoke
public class SimpleWrapper implements Wrapper{
private SimplePipeline pipeline = new SimplePipeline();
pipeline.setBasic(new SimpleWraperValve);
public void invoke(Request request, Response response){
pipeline.invoke(request, response); //context的子容器,
    }
}
public class SimpleContextMapper implements Mapper{
//...
public Container map(Request request, boolean update){
String contextPath = ((HttpRequest)request.getRequest().getContextPath();
String relativeURI= request.getDecodeRequestURI().subString(contextPath.length()); //get ServletPath
String name = context.findServletMapping(relativeURI);
return (Wrapper)context.findChild(name);     
}
}
//     3.调用context容器 阀的invoke
public class ClientIPLoggerValve implements Valve, Contained{
//...
    @Override
public void invoke(Request arg0, Response arg1, ValveContext valveContext) throws IOException,
ServletException {
valveContext.invokeNext(Request arg0, Response arg1);  //传递给管道中的下一个阀
// TODO Auto-generated method stub   
    }
}
public class HeaderLoggerValve implements Valve{
//...

@Override
public String getInfo() {
// TODO Auto-generated method stub
return null;
}
@Override
public Valve getNext() {
// TODO Auto-generated method stub
return null;
}
@Override
public void invoke(Request arg0, Response arg1) throws IOException,
ServletException {
// TODO Auto-generated method stub
        
}
}
  
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-95929-1-1.html 上篇帖子: tomcat 内存溢出 下篇帖子: 【JAVA WEB教程】jsp环境搭建+部署网站(eclipse+tomcat)【详细+图文】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表