<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Spring Boot四大核心組件, 你都會用嗎

          共 11166字,需瀏覽 23分鐘

           ·

          2021-08-31 20:41

          點擊上方 Java學習之道,選擇 設為星標

          每天18:30點,干貨準時奉上!

          來源: blog.csdn.net/u011909918/article/details/109647196?spm=1001.2014.3001.5501
          作者: 有人把我昵稱搶了

          Part1Spring Boot Starter

          1Starter的應用示例

          <dependency>
              <groupId>org.springframework.boot</groupId>
              <artifactId>spring-boot-starter-thymeleaf</artifactId>
          </dependency>

          <dependency>
              <groupId>org.mybatis.spring.boot</groupId>
              <artifactId>mybatis-spring-boot-starter</artifactId>
              <version>1.3.2</version>
          </dependency>

          在我們的Spring Boot項目種的POM文件中總會看到這兩種依賴:spring-boot-starter-xxxxxx-spring-boot-starter

          這就是spring boot的四大組件之一的starter。

          spring-boot-starter-thymeleaf

          mybatis-spring-boot-starter

          兩種starter的區(qū)別就是:

          • 官方提供的starter是這樣的:spring-boot-starter-xxx
          • 非官方的starter是這樣的:xxx-spring-boot-starter

          其中xxx就是我們想要依賴的組件或者jar包。上例就是我們spring boot用來引入thymeleaf引擎和mybatis框架所配置的依賴。引入之后通過簡單的約定配置就可以正常使用。比如:

          Thymeleaf引擎約定配置:

          ##前端引擎配置
          spring:
            thymeleaf:
              enabled: true
              servlet:
                content-type: text/html
              mode: HTML
              ## 頁面前綴
              prefix: classpath:/templates/
              ## 后綴
              suffix: .html

          Mybatis約定配置:

          mybatis:
            mapper-locations: classpath:mapper/*.xml  #注意:一定要對應mapper映射xml文件的所在路徑
            type-aliases-package: com.hi.ld.vo.system  # 注意:對應實體類的路徑
            configuration:
              log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

          下面讓我們來看看以前怎么配置thymeleaf。

          2Spring Boot之前的Thymeleaf和Mybatis應用

          廢話不多說,直接上代碼:

          1 Thymeleaf配置

          添加對應依賴:

          <dependency>
            <groupId>org.thymeleaf</groupId>
            <artifactId>thymeleaf-spring5</artifactId>
            <version>3.0.11.RELEASE</version>
          </dependency>
          <dependency>
            <groupId>org.thymeleaf.extras</groupId>
            <artifactId>thymeleaf-extras-java8time</artifactId>
            <version>3.0.4.RELEASE</version>
          </dependency>

          bean配置:

          <bean id="templateResolver"
                 class="org.thymeleaf.templateresolver.ServletContextTemplateResolver">

            <property name="prefix" value="/WEB-INF/templates/" />
            <property name="suffix" value=".html" />
            <property name="templateMode" value="HTML5" />
          </bean>

          <bean id="templateEngine"
                class="org.thymeleaf.spring4.SpringTemplateEngine">

            <property name="templateResolver" ref="templateResolver" />
          </bean>

          <bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">
            <property name="templateEngine" ref="templateEngine" />
          </bean>

          Mybatis配置

          添加對應依賴:

           <dependency>
             <groupId>org.springframework.boot</groupId>
             <artifactId>spring-boot-starter-jdbc</artifactId>
           </dependency>
           <dependency>
             <groupId>org.mybatis</groupId>
             <artifactId>mybatis</artifactId>
           </dependency>
           <dependency>
             <groupId>org.mybatis</groupId>
             <artifactId>mybatis-spring</artifactId>
           </dependency>

          bean配置:

          下面的第3, 4步驟就是Mybatis相關配置。第一步是引入資源配置。第二步是配置數據源

          <?xml version="1.0" encoding="UTF-8"?>
          <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context.xsd"
          >

           <!-- 配置整合mybatis過程 -->
           <!-- 1.配置數據庫相關參數properties的屬性:${url} -->
           <context:property-placeholder location="classpath:jdbc.properties" />

           <!-- 2.數據庫連接池 -->
           <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
            <!-- 配置連接池屬性 -->
            <property name="driverClass" value="${jdbc.driver}" />
            <property name="jdbcUrl" value="${jdbc.url}" />
            <property name="user" value="${jdbc.username}" />
            <property name="password" value="${jdbc.password}" />

            <!-- c3p0連接池的私有屬性 -->
            <property name="maxPoolSize" value="30" />
            <property name="minPoolSize" value="10" />
            <!-- 關閉連接后不自動commit -->
            <property name="autoCommitOnClose" value="false" />
            <!-- 獲取連接超時時間 -->
            <property name="checkoutTimeout" value="10000" />
            <!-- 當獲取連接失敗重試次數 -->
            <property name="acquireRetryAttempts" value="2" />
           </bean>

           <!-- 3.配置SqlSessionFactory對象 -->
           <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
            <!-- 注入數據庫連接池 -->
            <property name="dataSource" ref="dataSource" />
            <!-- 配置MyBaties全局配置文件:mybatis-config.xml -->
            <property name="configLocation" value="classpath:mybatis-config.xml" />
            <!-- 掃描entity包 使用別名 -->
            <property name="typeAliasesPackage" value="com.soecode.lyf.entity" />
            <!-- 掃描sql配置文件:mapper需要的xml文件 -->
            <property name="mapperLocations" value="classpath:mapper/*.xml" />
           </bean>

           <!-- 4.配置掃描Dao接口包,動態(tài)實現Dao接口,注入到spring容器中 -->
           <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <!-- 注入sqlSessionFactory -->
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
            <!-- 給出需要掃描Dao接口包 -->
            <property name="basePackage" value="com.soecode.lyf.dao" />
           </bean>
          </beans>

          小結

          • Starter 幫我們封裝好了所有需要的依賴,避免我們自己添加導致的一些Jar包沖突或者缺少包的情況;

          • Starter幫我們自動注入了需要的Bean實例到Spring 容器中,不需要我們手動配置(這個可以說是starter干的,實際上并不是,這里埋個坑,下面解答);

          所以: starter包的內容就是pom文件,就是一個依賴傳遞包。

          Part2Spring Boot Autoconfigure

          3autoconfigure 簡介

          autoconfigure在我們的開發(fā)中并不會被感知,因為它是存在與我們的starter中的。所以我們的每個starter都是依賴autoconfigure的:當然我們也可以把autoconfig的內容直接放在starter包里邊。

          spring-boot-autoconfigure:

          意:這里有個點,就是官網提供的configure大多數在spring-boot-autoconfigure包里邊,并沒有單獨創(chuàng)建新包。

          mybatis-spring-boot-autoconfigure

          小結

          autoconfigure內容是配置Bean實例到Spring容器的實際代碼實現包,然后提供給starter依賴。所以說1.2.3中的b項所說的配置Bean實例到Spring容器中實際是autoconfigure做的,因為是starter依賴它,所以也可以說是starter干的。

          所以:autocinfigure是starter體現出來的能力的代碼實現

          Part3Spring Boot CLI

          Spring Boot CLI是一個命令行使用Spring Boot的客戶端工具;主要功能如下:

          • 運行groovy腳本 => 官網2.1
          • 打包groovy文件到jar => 官網2.3
          • 初始化Spring Boot項目 => 官網2.4
          • 其他 先上個官網文檔: https://docs.spring.io/spring-boot/docs/current/reference/html/cli.html因為這個我們用的比較少,所以就不多贅述了。個人感覺比較流脾的功能就是命令行直接執(zhí)行groovy腳本了。

          Part4Spring Boot actuator

          actuator是Spring Boot的監(jiān)控插件,本身提供了很多接口可以獲取當前項目的各項運行狀態(tài)指標。

          官網文檔:https://docs.spring.io/spring-boot/docs/2.4.0/reference/html/production-ready-features.html#production-ready

          4名詞解釋:

          Endpoints: 需要監(jiān)控的端點。參考官網第二節(jié)官網文檔

          5可用的端點:

          下方的是web工程的端點。使用方法如下:

          4.1 添加依賴

          <dependency>
              <groupId>org.springframework.boot</groupId>
              <artifactId>spring-boot-starter-actuator</artifactId>
          </dependency>

          4.2 配置需要開啟監(jiān)控的端點

          management:
            endpoint:
              health: ## 開啟健康監(jiān)控端點
                enabled: true
              beans: ## 開啟Bean實例監(jiān)控端點
                enabled: true

          4.3 啟動服務并驗證

          啟動結果查看各個監(jiān)控信息

          瀏覽器訪問(查看監(jiān)控信息地址):http://localhost:9500/actuator查看服務健康狀態(tài):

          -- END --

           | 更多精彩文章 -



             
                    
          加我微信,交個朋友
                   
          長按/掃碼添加↑↑↑
                          

          瀏覽 118
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  黄色内射| 亚洲AV无码成人精品区欧洲 | 青娱乐偷拍视频99 | 操你逼逼 | 亚洲成人福利 |