欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot 2.5.0 重新設計的spring.sql.init 配置有啥用

 更新時間:2021年05月25日 14:18:47   作者:程序猿DD  
前幾天Spring Boot 2.5.0發(fā)布了,其中提到了關于Datasource初始化機制的調整,有讀者私信想了解這方面做了什么調整。那么今天就要詳細說說這個重新設計的配置內容,并結合實際情況說說我的理解和實踐建議

棄用內容

先來糾正一個誤區(qū)。主要之前在版本更新介紹的時候,存在一些表述上的問題。導致部分讀者認為這次的更新是Datasource本身初始化的調整,但其實并不是。這次重新設計的只是對Datasource腳本初始化機制的重新設計。

先來看看這次被棄用部分的內容(位于org.springframework.boot.autoconfigure.jdbc.DataSourceProperties),如果你有用過這些配置內容,那么新配置就很容易理解了。

/**
	 * Mode to apply when determining if DataSource initialization should be performed
	 * using the available DDL and DML scripts.
	 */
	@Deprecated
	private DataSourceInitializationMode initializationMode = DataSourceInitializationMode.EMBEDDED;

	/**
	 * Platform to use in the DDL or DML scripts (such as schema-${platform}.sql or
	 * data-${platform}.sql).
	 */
	@Deprecated
	private String platform = "all";

	/**
	 * Schema (DDL) script resource references.
	 */
	private List<String> schema;

	/**
	 * Username of the database to execute DDL scripts (if different).
	 */
	@Deprecated
	private String schemaUsername;

	/**
	 * Password of the database to execute DDL scripts (if different).
	 */
	@Deprecated
	private String schemaPassword;

	/**
	 * Data (DML) script resource references.
	 */
	@Deprecated
	private List<String> data;

	/**
	 * Username of the database to execute DML scripts (if different).
	 */
	@Deprecated
	private String dataUsername;

	/**
	 * Password of the database to execute DML scripts (if different).
	 */
	@Deprecated
	private String dataPassword;

	/**
	 * Whether to stop if an error occurs while initializing the database.
	 */
	@Deprecated
	private boolean continueOnError = false;

	/**
	 * Statement separator in SQL initialization scripts.
	 */
	@Deprecated
	private String separator = ";";

	/**
	 * SQL scripts encoding.
	 */
	@Deprecated
	private Charset sqlScriptEncoding;

對應到配置文件里的屬性如下(這里僅列出部分,就不全部列出了,主要就是對應上面源碼中的屬性):

spring.datasource.schema=
spring.datasource.schema-username=
spring.datasource.schema-password=
...

這些配置主要用來指定數據源初始化之后要用什么用戶、去執(zhí)行哪些腳本、遇到錯誤是否繼續(xù)等功能。

新的設計

Spring Boot 2.5.0開始,啟用了全新的配置方式,我們可以從這個類org.springframework.boot.autoconfigure.sql.init.SqlInitializationProperties里看到詳情。

下面我們通過一個簡單的例子來體驗這個功能的作用。

創(chuàng)建一個Spring Boot的基礎應用,并在pom.xml中引入和mysql的依賴:

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

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

在配置文件中增加數據源和初始化數據源的配置,具體如下:

spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# Spring Boot 2.5.0 init schema & data
# 執(zhí)行初始化腳本的用戶名稱
spring.sql.init.username=root
# 執(zhí)行初始化腳本的用戶密碼
spring.sql.init.password=
# 初始化的schema腳本位置
spring.sql.init.schema-locations=classpath*:schema-all.sql

根據上面配置的定義,接下來就在resource目錄下,創(chuàng)建腳本文件schema-all.sql,并寫入一些初始化表結構的腳本

create table test.user_info
(
    id          int unsigned auto_increment comment '用戶id'
        primary key,
    open_id     varchar(255)     default '' null comment '微信小程序openid',
    nick_name   varchar(255)     default '' null comment '微信名',
    head_img    varchar(255)     default '' null comment '微信頭像',
    sex         varchar(255)     default '' null comment '性別',
    phone       varchar(255)     default '' null comment '手機',
    province    varchar(255)     default '' null comment '注冊地址:省',
    city        varchar(255)     default '' null comment '注冊地址:城市',
    country     varchar(255)     default '' null comment '注冊地址:縣/區(qū)',
    status      tinyint unsigned default 0  not null comment '是否標記刪除 0:否 1:是',
    create_time datetime                    not null comment '創(chuàng)建時間',
    update_time datetime                    not null comment '更新時間'
)
comment '用戶表';

完成上面步驟之后,啟動應用。然后打開MySQL客戶端,可以看到在test庫下,多了一個user_info

通過上面的例子,不難想到這樣的功能主要可以用來管理應用啟動與數據庫配置的自動執(zhí)行,以減少應用部署過程中手工執(zhí)行的內容,降低應用部署的執(zhí)行步驟。

配置詳解

除了上面用到的配置屬性之外,還有一些其他的配置,下面詳細講解一下作用。

  • spring.sql.init.enabled:是否啟動初始化的開關,默認是true。如果不想執(zhí)行初始化腳本,設置為false即可。通過-D的命令行參數會更容易控制。
  • spring.sql.init.usernamespring.sql.init.password:配置執(zhí)行初始化腳本的用戶名與密碼。這個非常有必要,因為安全管理要求,通常給業(yè)務應用分配的用戶對一些建表刪表等命令沒有權限。這樣就可以與datasource中的用戶分開管理。
  • spring.sql.init.schema-locations:配置與schema變更相關的sql腳本,可配置多個(默認用;分割)
  • spring.sql.init.data-locations:用來配置與數據相關的sql腳本,可配置多個(默認用;分割)
  • spring.sql.init.encoding:配置腳本文件的編碼
  • spring.sql.init.separator:配置多個sql文件的分隔符,默認是;
  • spring.sql.init.continue-on-error:如果執(zhí)行腳本過程中碰到錯誤是否繼續(xù),默認是false`;所以,上面的例子第二次執(zhí)行的時候會報錯并啟動失敗,因為第一次執(zhí)行的時候表已經存在。

應用建議

關于這些配置的應用,相信聰明的你一定會把它與數據庫的版本管理聯系起來(因為可以自動的執(zhí)行腳本)。

那么依靠這些配置,是否可以勝任業(yè)務應用部署時候數據庫初始化的自動化實現呢?

個人認為就上述所介紹的配置,雖然具備了一定的自動執(zhí)行能力。但由于缺失對當前環(huán)境的判斷能力,所以要應對實際的部署場景來說,還是遠遠不夠的。

如果要自動化的管理數據庫表結構、初始化數據的話,我的建議是:

  • 默認提供的這個初始化功能可以且僅用于單元測試,自動創(chuàng)建數據庫結構與初始化數據,使用完畢后銷毀??梢苑奖愕目刂泼看螁卧獪y試的執(zhí)行環(huán)境一致。
  • 應用在環(huán)境部署的時候,還是要使用之前介紹過的Flyway來實現,如何使用可見之前的分享:使用Flyway來管理數據庫版本。
  • 聯合Flyway一同使用,通過org.springframework.jdbc.datasource.init.DataSourceInitializer來定義更復雜的執(zhí)行邏輯。

更多本系列免費教程連載「點擊進入匯總目錄」

代碼示例

本文的相關例子可以查看下面?zhèn)}庫中的chapter3-13目錄:

Github:https://github.com/dyc87112/SpringBoot-Learning/

Gitee:https://gitee.com/didispace/SpringBoot-Learning/

到此這篇關于Spring Boot 2.5.0 重新設計的spring.sql.init 配置有啥用?的文章就介紹到這了,更多相關spring.sql.init 配置內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • java Spring松耦合高效應用簡單實例分析

    java Spring松耦合高效應用簡單實例分析

    在Java項目,龐大的對象依賴關系將一直緊密耦合引起對象難以管理或修改。在這種情況下,可以使用Spring框架作為一個核心模塊輕松高效地管理所有的對象依賴。本文章向大家介紹Spring松耦合的實例,需要的朋友可以參考一下。
    2016-12-12
  • Java設計模式之備忘錄模式_動力節(jié)點Java學院

    Java設計模式之備忘錄模式_動力節(jié)點Java學院

    我們在編程的時候,經常需要保存對象的中間狀態(tài),當需要的時候,可以恢復到這個狀態(tài)。接下來通過本文給大家分享java設計模式之備忘錄模式,感興趣的的朋友一起看看吧
    2017-08-08
  • logback輸出日志屏蔽quartz的debug等級日志方式

    logback輸出日志屏蔽quartz的debug等級日志方式

    這篇文章主要介紹了logback輸出日志屏蔽quartz的debug等級日志方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java 關于遞歸的調用機制精細解讀

    Java 關于遞歸的調用機制精細解讀

    關于遞歸是什么,簡單的說: 遞歸就是方法自己調用自己,每次調用時 傳入不同的變量.遞歸有助于編程者解決復雜的問題,同時可以讓代碼變得簡潔
    2021-10-10
  • Zookeeper?Curator使用介紹

    Zookeeper?Curator使用介紹

    curator是Net?ix公司開源的?套Zookeeper客戶端框架,和ZKClient?樣,Curator解決了很多Zookeeper客戶端非常底層的細節(jié)開發(fā)?作,包括連接重連,反復注冊Watcher和NodeExistsException異常等,是最流行的Zookeeper客戶端之?
    2022-09-09
  • 詳解Java中Javassist的使用

    詳解Java中Javassist的使用

    常用的一些操作字節(jié)碼的技術有?ASM、AspectJ、Javassist?等。本文主要為大家介紹了Javassist使用的相關知識,感興趣的小伙伴可以了解一下
    2023-04-04
  • 普通類注入不進spring bean的解決方法

    普通類注入不進spring bean的解決方法

    這篇文章主要介紹了普通類注入不進spring bean的解決方法,幫助大家更好的理解和使用spring bean,感興趣的朋友可以了解下
    2021-01-01
  • 使用SpringSecurity 進行自定義Token校驗

    使用SpringSecurity 進行自定義Token校驗

    這篇文章主要介紹了使用SpringSecurity 進行自定義Token校驗操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Netty進階之ChannelPoolMap源碼解析

    Netty進階之ChannelPoolMap源碼解析

    這篇文章主要介紹了Netty進階之ChannelPoolMap源碼解析,ChannelPoolMap是用來存儲ChannelPool和指定key的一個集合Map,實際的應用場景就是服務器端是一個分布式集群服務,擁有多個配置地址,這樣我們就可以配置多個服務地址,減輕單臺服務器的壓力,需要的朋友可以參考下
    2023-11-11
  • SpringBoot應用監(jiān)控Actuator使用隱患及解決方案

    SpringBoot應用監(jiān)控Actuator使用隱患及解決方案

    SpringBoot的Actuator 模塊提供了生產級別的功能,比如健康檢查,審計,指標收集,HTTP 跟蹤等,幫助我們監(jiān)控和管理Spring Boot 應用,本文將給大家介紹SpringBoot應用監(jiān)控Actuator使用隱患及解決方案,需要的朋友可以參考下
    2024-07-07

最新評論