1、将AnnotationConfigServletWebServerApplicationContext上下文设置到
tomcat的ApplicationContextFacade上下文的代码流程
org.apache.catalina.core.StandardContext#startInternal----》 org.springframework.boot.web.embedded.tomcat.TomcatStarter#onStartup----》 getSelfInitializer().onStartup(servletContext)----》 org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext#selfInitialize----》 org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext#prepareWebApplicationContext----》 servletContext.setAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE, this);
2、DispatchServlet初始化流程(第一次访问时才会初始化)
org.apache.catalina.core.StandardWrapper#allocate----》 org.apache.catalina.core.StandardWrapper#initServlet----》 javax.servlet.GenericServlet#init(javax.servlet.ServletConfig)----》 org.springframework.web.servlet.HttpServletBean#init----》 org.springframework.web.servlet.FrameworkServlet#initServletBean----》 org.springframework.web.servlet.FrameworkServlet#initWebApplicationContext----》 org.springframework.web.servlet.DispatcherServlet#onRefresh----》 org.springframework.web.servlet.DispatcherServlet#initStrategies
3、springboot tomcat启动代码流程
org.springframework.context.support.AbstractApplicationContext#finishRefresh----》 org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext#startWebServer----》 org.springframework.boot.web.embedded.tomcat.TomcatWebServer#start----》、 org.springframework.boot.web.embedded.tomcat.TomcatWebServer#addPreviouslyRemovedConnectors----》 org.apache.catalina.core.StandardService#addConnector----》 connector.start();----》org.apache.catalina.connector.Connector org.apache.catalina.util.LifecycleBase#start----》 org.apache.catalina.connector.Connector#startInternal----》 protocolHandler.start()----》Http11NioProtocol org.apache.coyote.AbstractProtocol#start----》 endpoint.start();----》org.apache.tomcat.util.net.NioEndpoint org.apache.tomcat.util.net.AbstractEndpoint#start----》 org.apache.tomcat.util.net.NioEndpoint#startInternal----》 此方法做了三件事情:
1、初始化线程池(Poller线程监听到socket事件会交给此线程池进行业务处理):
org.apache.tomcat.util.net.AbstractEndpoint#createExecutor----》
org.apache.tomcat.util.threads.ThreadPoolExecutor#ThreadPoolExecutor(int, int, long, java.util.concurrent.TimeUnit, java.util.concurrent.BlockingQueue<java.lang.Runnable>, java.util.concurrent.ThreadFactory)----》
java.util.concurrent.ThreadPoolExecutor#prestartAllCoreThreads(初始化所有核心线程)
2、创建Poller线程并启动,开始监听socket事件
poller = new Poller();----》org.apache.tomcat.util.net.NioEndpoint.Poller
pollerThread.start();----》
org.apache.tomcat.util.net.NioEndpoint.Poller#run----》
while (true)----》(死循环)
keyCount = selector.selectNow();----》
processKey(sk, socketWrapper);----》
else if (!processSocket(socketWrapper, SocketEvent.OPEN_READ, true))----》
org.apache.tomcat.util.net.AbstractEndpoint#processSocket----》
sc = createSocketProcessor(socketWrapper, event);----》(创建org.apache.tomcat.util.net.NioEndpoint.SocketProcessor)
Executor executor = getExecutor();----》(获取初始化的线程池)
org.apache.tomcat.util.net.AbstractEndpoint#getExecutor----》
executor.execute(sc);(委派给业务线程池执行)
2.1 业务线程池执行流程
executor.execute(sc);----》
java.lang.Thread#run----》(org.apache.tomcat.util.threads.TaskThread)
org.apache.tomcat.util.threads.TaskThread.WrappingRunnable#run----》
org.apache.tomcat.util.net.SocketProcessorBase#run----》
org.apache.tomcat.util.net.NioEndpoint.SocketProcessor#doRun----》
state = getHandler().process(socketWrapper, event);----》
org.apache.coyote.AbstractProtocol.ConnectionHandler#process----》
state = processor.process(wrapper, status);----》
org.apache.coyote.AbstractProcessorLight#process----》
state = service(socketWrapper);----》
org.apache.coyote.http11.Http11Processor#service----》
getAdapter().service(request, response);----》
request = connector.createRequest();(创建Request)
response = connector.createResponse();(创建Response)----》
connector.getService().getContainer().getPipeline().getFirst().invoke(
request, response);----》
org.apache.catalina.core.StandardEngineValve#invoke----》
host.getPipeline().getFirst().invoke(request, response);----》
org.apache.catalina.valves.ErrorReportValve#invoke----》
getNext().invoke(request, response);----》
org.apache.catalina.core.StandardHostValve#invoke----》
context.getPipeline().getFirst().invoke(request, response);----》
org.apache.catalina.authenticator.AuthenticatorBase#invoke----》
getNext().invoke(request, response);----》
org.apache.catalina.core.StandardContextValve#invoke----》
wrapper.getPipeline().getFirst().invoke(request, response);----》
org.apache.catalina.core.StandardWrapperValve#invoke----》
servlet = wrapper.allocate();----》
org.apache.catalina.core.StandardWrapper#allocate----》
filterChain.doFilter(request.getRequest(), response.getResponse());----》
org.apache.catalina.core.ApplicationFilterChain#doFilter----》
internalDoFilter(request,response);----》
org.apache.catalina.core.ApplicationFilterChain#internalDoFilter----》
filter.doFilter(request, response, this);----》
org.springframework.web.filter.OncePerRequestFilter#doFilter----》
doFilterInternal(httpRequest, httpResponse, filterChain);----》
org.springframework.web.filter.CharacterEncodingFilter#doFilterInternal----》
filterChain.doFilter(request, response);----》
org.apache.catalina.core.ApplicationFilterChain#doFilter----》
internalDoFilter(request,response);----》(遍历执行filter链)
servlet.service(request, response);----》(DispatchServlet)
javax.servlet.http.HttpServlet#service(javax.servlet.ServletRequest, javax.servlet.ServletResponse)----》
service(request, response);----》(DispatchServlet)
org.springframework.web.servlet.FrameworkServlet#service----》
super.service(request, response);----》
javax.servlet.http.HttpServlet#service(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse)----》
doGet(req, resp);----》
org.springframework.web.servlet.FrameworkServlet#doGet----》
processRequest(request, response);----》
org.springframework.web.servlet.FrameworkServlet#processRequest----》
doService(request, response);----》
org.springframework.web.servlet.DispatcherServlet#doService----》
doDispatch(request, response);----》
org.springframework.web.servlet.DispatcherServlet#doDispatch----》
mv = ha.handle(processedRequest, response, mappedHandler.getHandler());----》
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter#handle----》
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter#handleInternal----》
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter#invokeHandlerMethod----》
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod#invokeAndHandle----》
org.springframework.web.method.support.InvocableHandlerMethod#invokeForRequest----》
org.springframework.web.method.support.InvocableHandlerMethod#doInvoke----》
java.lang.reflect.Method#invoke
3、初始化Acceptor线程并启动,监听连接事件并向Poller线程注册感兴趣的socker事件
startAcceptorThread();----》
acceptor = new Acceptor<>(this);----》
t.start();----》
org.apache.tomcat.util.net.Acceptor#run----》
while (endpoint.isRunning())----》(不断轮询)
socket = endpoint.serverSocketAccept();----》
if (!endpoint.setSocketOptions(socket))----》
Socket sock = socket.socket();----》
poller.register(channel, socketWrapper);----》(向Poller线程注册感兴趣的socker事件)
socketWrapper.interestOps(SelectionKey.OP_READ);
|