Jetty6的架构

Jetty6的架构
Connector(连接器)集合负责接收HTTP连接。handler(处理器)集合负责处理连接请求并给予响应。而Jetty Server(服务器)则是前两者的管道连接器。负责创建并初始化connector、handler、ThreadPool组件,然后调用start方法启动他们。ThreadPool(线程池)为他们完成工作提供线程。
Jetty Server演示代码

Java代码 Jetty6的架构Jetty6的架构Jetty6的架构
  1. //1:定义server
  2. Serverserver=newServer();
  3. //2:把连接器集合放到server里
  4. Connectorconnector=newSelectChannelConnector();
  5. connector.setPort(8080);
  6. server.setConnectors(newConnector[]{connector});
  7. //3:并把处理器集合放到server里
  8. Handlerparam=newParamHandler();
  9. Handlerhello=newHelloHandler();
  10. HandlerCollectionhandlers=newHandlerCollection();
  11. handlers.setHandlers(newHandler[]{param,hello});
  12. server.setHandler(handlers);
  13. //4:启动server
  14. server.start();
  15. server.join();
//1:定义server Server server = new Server(); //2:把连接器集合放到server里 Connector connector=new SelectChannelConnector(); connector.setPort(8080); server.setConnectors(new Connector[]{connector}); //3:并把处理器集合放到server里 Handler param=new ParamHandler(); Handler hello=new HelloHandler(); HandlerCollection handlers = new HandlerCollection(); handlers.setHandlers(new Handler[]{param,hello}); server.setHandler(handlers); //4:启动server server.start(); server.join();

模式

Jetty6的架构

jetty遵循一些比较规范的模式,最抽象的概念通过接口定义,如连接器,处理器和缓冲区。在抽象类中实现这些接口的通用操作,如AbstractConnector, AbstractHandler and AbstractBuffer。

Connectors

Jetty6的架构

连接器表示协议的处理者,负责解析请求并生成响应。不同类型的连接器在其基于的协议下有效,如调度模型和IO API的使用:

•SocketConnector - for few busy connections or when NIO is not available.
•BlockingChannelConnector - for few busy connections when NIO is available
•SelectChannelConnector - for many mostly idle connections or asynchronous handling of Ajax requests.
•SslSocketConnector - 没有使用NIO的SSL连接器。
•SslSelectChannelConnector - 使用非阻塞NIO支持的SSL连接器。
•AJPConnector AJP protocol support for connections from apache mod_jk or mod_proxy_ajp

connectors的使用代码

Java代码 Jetty6的架构Jetty6的架构Jetty6的架构
  1. Connectorconnector=newSelectChannelConnector();
  2. connector.setPort(8080);
Connector connector=new SelectChannelConnector(); connector.setPort(8080);

Handlers

Jetty6的架构

Handler组件负责处理接收到的请求. handler核心的API是handle方法:

Java代码 Jetty6的架构Jetty6的架构Jetty6的架构
  1. publicvoidhandle(Stringtarget,HttpServletRequestrequest,HttpServletResponseresponse,intdispatch)
  2. throwsIOException,ServletException;
public void handle(String target, HttpServletRequest request, HttpServletResponse response, int dispatch) throws IOException, ServletException;

这个方法的实现可以处理请求,传递请求到另外一个处理器(或者servlet),或修改并包装请求并传递出去。有三种类型的处理器:

  1. Coordinating Handlers - 负责路由请求到其他处理器的处理器(eg HandlerCollection, ContextHandlerCollection)
  2. Filtering Handlers - 负责增加请求并传递到其他处理器的处理器(eg. HandlerWrapper, ContextHandler, SessionHandler)
  3. Generating Handlers - 负责产生内容的处理器(eg ResourceHandler and ServletHandler)

Handler代码如下

Java代码 Jetty6的架构Jetty6的架构Jetty6的架构
  1. Handlerhandler=newHelloHandler();
  2. server.setHandler(handler);
  3. publicstaticclassHelloHandlerextendsAbstractHandler
  4. {
  5. publicvoidhandle(Stringtarget,HttpServletRequestrequest,HttpServletResponseresponse,intdispatch)throwsIOException,ServletException
  6. {
  7. Requestbase_request=(requestinstanceofRequest)?(Request)request:HttpConnection.getCurrentConnection().getRequest();
  8. base_request.setHandled(true);
  9. response.setContentType("text/html");
  10. response.setStatus(HttpServletResponse.SC_OK);
  11. response.getWriter().println("<h1>HelloOneHandler</h1>");
  12. }
  13. }
Handler handler=new HelloHandler(); server.setHandler(handler); public static class HelloHandler extends AbstractHandler { public void handle(String target, HttpServletRequest request, HttpServletResponse response, int dispatch) throws IOException, ServletException { Request base_request = (request instanceof Request) ? (Request)request:HttpConnection.getCurrentConnection().getRequest(); base_request.setHandled(true); response.setContentType("text/html"); response.setStatus(HttpServletResponse.SC_OK); response.getWriter().println("<h1>Hello OneHandler</h1>"); } }

Servlets

Context

Contexts是一种处理器,负责组织其他特定URI上下文路径或者一个虚拟机的处理器。通常情况下一个上下文必须有:

  • 一个上下文路径,负责通过上下文定义哪一个请求被处理。 (eg /myapp )
  • 一个基于静态内容的资源(a docroot)
  • 一个类加载器去获得指定上下文中的类(通常在docroot/WEB-INF/classes下)
  • 虚拟机名称

上下文实现包括:

  • ContextHandler
  • Servlet Context
  • a Web Application Context

Context示意代码:

Java代码 Jetty6的架构Jetty6的架构Jetty6的架构
  1. ContextHandlercontext=newContextHandler();
  2. context.setContextPath("/");
  3. context.setResourceBase(".");
  4. context.setClassLoader(Thread.currentThread().getContextClassLoader());
  5. server.setHandler(context);
ContextHandler context = new ContextHandler(); context.setContextPath("/"); context.setResourceBase("."); context.setClassLoader(Thread.currentThread().getContextClassLoader()); server.setHandler(context);

Web Applications

Jetty6的架构
一个WebAppContext是servlet Context的子类,它提供web应用程序标准的层次结构,以及session, security, listeners, filter, servlets 和JSP的配置。

Java代码 Jetty6的架构Jetty6的架构Jetty6的架构
  1. WebAppContextwebapp=newWebAppContext();
  2. webapp.setContextPath("/");
  3. webapp.setWar(jetty_home+"/webapps/test");
  4. webapp.setDefaultsDescriptor(jetty_home+"/etc/webdefault.xml");
  5. server.setHandler(webapp);
WebAppContext webapp = new WebAppContext(); webapp.setContextPath("/"); webapp.setWar(jetty_home+"/webapps/test"); webapp.setDefaultsDescriptor(jetty_home+"/etc/webdefault.xml"); server.setHandler(webapp);

参考资料