好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 傳統tomcat啟動服務與springboot啟動內置tomcat服務的區別(推薦)

傳統tomcat啟動服務與springboot啟動內置tomcat服務的區別(推薦)

熱門標簽:怎么找到沒有地圖標注的店 打400電話怎么辦理收費 上海申請高400開頭的電話 400電話辦理介紹信 宿城區電話機器人找哪家 河南防封號電銷機器人是什么 麗江真人語音電話外呼系統 10086外包用的什么外呼系統 福州企業電銷機器人排名

spring整合springmvc

  •  spring整合springmvc中web.xml配置如下,tomcat在啟動過程中會加載web.xml中的內容,ContextLoaderListener實現了tomcat里面的ServletContextListener接口,所以在tomcat容器啟動過程通過ContextLoaderListener來進行spring容器的初始化操作,并將classpath:spring/applicationContext-*.xml指定下的spring配置文件加載,該配置文件我只配置了<context:component-scan base-package=“org.com.yp”/>,代表通過掃描org.com.yp包下的類,包含@Component @Controller@Service等注解等類,進行bean注冊。
  • bean注冊是通過AbstractXmlApplicationContext.loadBeanDefinitions該類的方法進行bean定義加載的。

spring中加載bean定義是在org.springframework.context.ConfigurableApplicationContext#refresh方法中的ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory()方法加載bean的,該方法之后會調用org.springframework.context.support.AbstractRefreshableApplicationContext#refreshBeanFactory方法創建bean工廠,并加載的bean定義。

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xmlns="http://java.sun.com/xml/ns/javaee"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
                             http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>Archetype Created Web Application</display-name>
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <!-- 加載spring容器 -->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:spring/applicationContext-*.xml</param-value>
  </context-param>
​
  <servlet>
    <servlet-name>mvc-dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!-- 配置springMVC需要加載的配置文件-->
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:spring/spring-*.xml</param-value>
    </init-param>
  </servlet>
​
  <servlet-mapping>
    <servlet-name>mvc-dispatcher</servlet-name>
    <!-- 默認匹配所有的請求 -->
    <url-pattern>/</url-pattern>
  </servlet-mapping>
</web-app>

當tomcat容器啟動后,通過路徑訪問資源時,第一次會調用org.springframework.web.servlet.HttpServletBean#init方法,之后的http請求就不會再方法該方法類;HttpServletBean實現了Servlet接口的規范,所以經過瀏覽器的請求經過servlet接口初始化執行init方法時,會再從spring容器中去加載springmvc配置中定義的加載類,spring與springmvc是父子容器的關系,下面是HttpServletBean的init方法

public final void init() throws ServletException {
		// Set bean properties from init parameters.
		PropertyValues pvs = new ServletConfigPropertyValues(getServletConfig(), this.requiredProperties);
		if (!pvs.isEmpty()) {
			try {
				BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(this);
				ResourceLoader resourceLoader = new ServletContextResourceLoader(getServletContext());
				bw.registerCustomEditor(Resource.class, new ResourceEditor(resourceLoader, getEnvironment()));
				initBeanWrapper(bw);
				bw.setPropertyValues(pvs, true);
			}
			catch (BeansException ex) {
				if (logger.isErrorEnabled()) {
					logger.error("Failed to set bean properties on servlet '" + getServletName() + "'", ex);
				}
				throw ex;
			}
		}

        // 最后會調用org.springframework.context.ConfigurableApplicationContext#refresh容器的刷新方法,
        // 進行springmvc容器初始化
		initServletBean();
	}
    }

springboot啟動容器

  •  springboot啟動的方式則是先在springboot的org.springframework.boot.SpringApplication#run(java.lang.String…)方法中就初始化了spring的上下文環境(里面包含bean工廠),之后通過org.springframework.boot.SpringApplication#refreshContext方法調用Spring容器中的ConfigurableApplicationContext#refresh方法初始化bean.
  • 在spring與springmvc整合的環境中,bean定義的加載是在org.springframework.context.support.AbstractApplicationContext#obtainFreshBeanFactory方法,而springboot中是在

org.springframework.context.support.AbstractApplicationContext#invokeBeanFactoryPostProcessors方法,該方法中通過ConfigurationClassPostProcessor類去加載bean定義,該類實現了BeanDefinitionRegistryPostProcessor接口,這個接口允許對bean定義進行加工處理。

// spring中的BeanDefinitionRegistryPostProcessor是BeanFactoryPostProcessor的子接口,
// BeanFactoryPostProcessor的作用是在bean的定義信息已經加載但還沒有初始化的時候執行方法postProcessBeanFactory()方法,
// 而BeanDefinitionRegistryPostProcessor是在BeanFactoryPostProcessor的前面執行,在源碼
// org.springframework.context.support.PostProcessorRegistrationDelegate#invokeBeanFactoryPostProcessors()方法里面定義了執行順序
// BeanFactoryPostProcessor是bean工廠的bean屬性處理容器,說通俗一些就是可以管理我們的bean工廠內所有的beandefinition(未實例化)數據,可以隨心所欲的修改屬性。
public void refresh() throws BeansException, IllegalStateException {
        synchronized (this.startupShutdownMonitor) {
            prepareRefresh();
            
            //獲取告訴子類初始化Bean工廠 將bean加載到緩存中 spring springmvc整合是在這初始化bean的
            ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory();
            
            prepareBeanFactory(beanFactory);
​
            try {
                postProcessBeanFactory(beanFactory);
​
                // springboot容器啟動加載到這時,初始化了下面幾個bean name
                //0 = "org.springframework.context.annotation.internalConfigurationAnnotationProcessor" =》對應ConfigurationClassPostProcessor類
                //1 = "org.springframework.context.annotation.internalAutowiredAnnotationProcessor" =》 AutowiredAnnotationBeanPostProcessor
                //2 = "org.springframework.context.annotation.internalCommonAnnotationProcessor" =》 CommonAnnotationBeanPostProcessor
                //3 = "org.springframework.context.event.internalEventListenerProcessor" =》 EventListenerMethodProcessor
                //4 = "org.springframework.context.event.internalEventListenerFactory" =》 DefaultEventListenerFactory
                // 調用我們的bean工廠的后置處理器.加載bean定義(不是實例化),通過ConfigurationClassPostProcessor去加載啟動類中的掃描路徑
                // 然后將路徑下到bean加載進來
                invokeBeanFactoryPostProcessors(beanFactory);
​
                registerBeanPostProcessors(beanFactory);
​
                initMessageSource();
​
                initApplicationEventMulticaster();
​
                // 這個方法同樣也是留個子類實現的springboot也是從這個方法進行啟動tomat的.
                onRefresh();
​
                registerListeners();
​
                //實例化我們剩余的單實例bean.
                finishBeanFactoryInitialization(beanFactory);
​
                // 最后容器刷新 發布刷新事件(Spring cloud也是從這里啟動的)
                finishRefresh();
            }
​
            catch (BeansException ex) {
                if (logger.isWarnEnabled()) {
                    logger.warn("Exception  encountered during context initialization - " +
                            "cancelling refresh attempt: " + ex);
                }
​
                // Destroy already created singletons to avoid dangling resources.
                destroyBeans();
​
                // Reset 'active' flag.
                cancelRefresh(ex);
​
                // Propagate exception to caller.
                throw ex;
            }
​
            finally {
                // Reset common introspection caches in Spring's core, since we
                // might not ever need metadata for singleton beans anymore...
                resetCommonCaches();
            }
        }
    }

到此這篇關于傳統tomcat啟動服務與springboot啟動內置tomcat服務的區別的文章就介紹到這了,更多相關tomcat啟動服務與springboot啟動內置tomcat服務區別內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:雞西 面試通知 荊門 朝陽 連云港 隴南 遵義 運城

巨人網絡通訊聲明:本文標題《傳統tomcat啟動服務與springboot啟動內置tomcat服務的區別(推薦)》,本文關鍵詞  傳統,tomcat,啟動,服務,與,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《傳統tomcat啟動服務與springboot啟動內置tomcat服務的區別(推薦)》相關的同類信息!
  • 本頁收集關于傳統tomcat啟動服務與springboot啟動內置tomcat服務的區別(推薦)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 久久er精品视频| 香港三级黄色电影| 国产aaa毛片| 91国精产品秘?一区二区三区| 我的恋爱画风有些不正常| 亲嘴伸进内衣揉胸口激烈视频.| 我要看女人的逼| 91在线无码精品秘?国产软件| 98精品国产91久久久久久青草| 桃花源高清在线观看| 国产AV精品亚洲AV蟹美脚| 在线观看www成人影院| 久久国产一级毛片| 欧美一级特黄级AAA片| 女女舔| 短篇强高h系列双性| 日本级婬乱片古装| 四虎成人影视8848亚洲| 正在播放国产多p交换视频| 免费老外的毛片清高| 国产精品99久久久久久精品小说 | 在线观看国产一区| 色鬼压床大尺度做爰未删减| 50歳のバツ1熟女とハメ撮り| 特黄做受又粗又长又大又硬| 欧美日韩影院| 女人被添荫蒂舒服了的更新时间| 够了够了到高c了好多水视频| 好男人神马影院www在线观看| XXX亲子伦XXXinin| 国产毛片精品国产一区二区三区| 欧美黄色一级在线| 叶子楣三级露全乳视频网站 | 韩国理伦电影手机在线观看 | 免费无遮挡??动画网站下载哔咔| 亚洲AV无码国产日韩欧美99 | 皇上好涨奴婢夹不文H| 色噜噜狠狠一区二区三区四区偷拍| 霸道少爷玩奴GAy片| 花房姑娘电影观看| 变态拳头交视频一区二区|