栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Flyway-Springboot快速集成参考

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Flyway-Springboot快速集成参考

准备
  • 官网地址: documentation - Flyway by Redgate • Database Migrations Made Easy.
  • 快速集成: Community Plugins and Integrations - Community Plugins and Integrations - Flyway by Redgate • Database Migrations Made Easy.(首页位置点击插件进入即可)

说明:

  • 开箱即用: “How-to” Guides
  • Flyway迁移脚本命名规范:Migrations - Migrations - Flyway by Redgate • Database Migrations Made Easy.

Spring Boot supports two higher-level migration tools: Flyway and Liquibase.

如果你是为了快速集成组件到当前项目中,可以参考本篇文章的中的关键配置达到应用的效果。但是你如果想要知道为什么要这么做,作何解释相信上面的链接导引一定可以节省你很多时间!!!

集成

Springboot集成

参考地址: Spring Boot - Community Plugins and Integrations: Spring Boot - Flyway by Redgate • Database Migrations Made Easy.

加入依赖信息(备注版本:5.2.0)


    org.flywaydb
    flyway-core
    8.3.0




compile "org.flywaydb:flyway-core:8.3.0"

集成到springboot中可选的配置:

Common Application Properties

Spring项目配置文件

精简配置即可实现springboot对于flyway的集成:

spring.flyway.enabled=true
spring.flyway.locations=classpath:flyway/sql
spring.flyway.baseline-on-migrate=true

# 说明,在spring boot 1.x中,属性前缀为flyway,在spring boot 2.x中为spring.flyway,需要区分不同版本

location参数定义了flyway文件执行的位置,具体定义文件的格式以及使用我在官网也找到了对应的参考地址:

“How-to” Guides

关于locations参数的说明这里多提一句,在加成配置文件地址的时候支持两种方式:classpath、 filesystem

spring.flyway.locations=classpath:db/migration,filesystem:/opt/migration

不得不说,springboot家的文档还是比较全的,但是如果不是有合适切入口,找这些文档还是挺费时间的!

在项目配置的locations的位置进编写指定的脚本文件即可:

脚本配置文件规则

在集成到Springboot项目中的时候我们指定了一个配置文件的属性叫做:locations,这个属性制定了生效的脚本所在的位置,但是脚本文件的名称具有一定的约束性,还是老样子先给出官网的解释文档:(我始终认为,网上搜罗的博客或者是文章大部分都是从官网抄过来的,但是工作了一段时间之后我们对这些问题解决方案和知识的来源要有所思考,不能大家说什么就是什么。)

Migrations - Migrations - Flyway by Redgate • Database Migrations Made Easy.

简单总结官网说的大致意思,脚本执行的前缀是有限制的:V U R。分表代表执行的操作为 执行一次,撤销操作 重复迁移操作。具体详细说明可以去官网查询了解。

实际上在真实项目开发中,我想在大多数使用的脚本还是这个样子:

classpath: 
		V1_1__create_sql.sql
    V1_2__create_sql.sql
    V1_3__create_sql.sql
    V1_4__create_sql.sql
    ....
    VXXX_XXX__create_sql.sql

实际上组件提供的功能你可以编写达到的效果是这个样子的:

自动装配

为何能够实现自动配置可以参考springboot配置包文件中的自动配置类:

我这里并打算对这个组件的源代码做深入的了解,所以只是列除了能够实现自动配置的原因。后面,留一个章节等我弄懂这个东西的大致实现原理,会在后面在做阐述。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/694873.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号