SpringBoot 项目集成 Flyway

在 Spring Boot 项目中集成 Flyway 并结合 Nacos 的配置管理,可以按照以下步骤进行操作:

添加 Flyway 依赖

Groovy 复制代码
implementation 'org.flywaydb:flyway-core'

配置 Nacos 中的数据库和 Flyway 参数

Flyway 默认是读取 spring.datasource 中的配置作为数据源信息,当然也可以通过 java 代码或者 spring.flyway 单独进行配置数据源信息。

java 复制代码
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/your_db?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC
    username: root
    password: your_password
    driver-class-name: com.mysql.cj.jdbc.Driver
  
  # Flyway配置
  flyway:
    enabled: true  # 启用Flyway(默认true)
    baseline-on-migrate: true  # 对已存在表结构的数据库执行基准迁移(首次使用时建议开启)
    baseline-version: 1  # 基准版本号(默认1)
    locations: classpath:db/migration  # 迁移脚本存放路径(默认值)
    clean-disabled: true  # 禁用clean命令(生产环境必须开启,防止误删数据)
    validate-on-migrate: true  # 迁移时验证脚本(默认true)

创建数据库迁移脚本

在项目的 src/main/resources 目录下创建 db/migration 文件夹,并按照 Flyway 的命名规范编写 SQL 脚本:

  • 版本迁移脚本:V{版本号}__{描述}.sql(如V1__init_schema.sql、V2__add_user_table.sql);

启动项目验证集成效果

启动 Spring Boot 项目后,Flyway 会自动执行以下操作:

  • 检查数据库中是否存在flyway_schema_history表(不存在则创建);
  • 对比db/migration目录下的脚本与flyway_schema_history表中的记录;
  • 执行未执行过的脚本,并将执行记录写入flyway_schema_history表;
  • 如果启动日志中出现类似以下内容,说明集成成功:
html 复制代码
Successfully applied 1 migration to schema `your_db` (execution time 00:00.035s)

进阶配置

通过上述配置,已经能成功集成 Flyway。当然,Flyway 还具备一些定制化配置,如果需要用到可以自行查询。

相关推荐
禹中一只鱼2 分钟前
【IDEA 出现 `IDE error occurred`】
java·ide·spring boot·intellij-idea
西凉的悲伤2 分钟前
Guava类库——Lists.partition() 高效分批处理列表数据
java·guava
weixin_408099673 分钟前
【保姆级教程】按键精灵调用 OCR 文字识别 API(从0到1完整实战 + 可运行脚本)
java·前端·人工智能·后端·ocr·api·按键精灵
brahmsjiang5 分钟前
Java类加载机制解析:从JVM启动到双亲委派,再到Android的特殊实现
android·java·jvm
yaaakaaang7 分钟前
十一、享元模式
java·享元模式
卓怡学长8 分钟前
基于 SpringBoot 的生活信息分享平台,从 0 到 1 完整实现(附源码 + 数据库)
java·数据库·spring boot·tomcat·maven
ID_180079054739 分钟前
Python解析小红书(XHS)笔记评论 API,json数据返回参考
java·服务器·数据库
努力努力再努力wz11 分钟前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!(附B树实现源码)
java·linux·开发语言·数据结构·c++·b树·算法
hero.fei12 分钟前
RoaringBitmap在SpringBoot中的使用以及与BitSet对比
java·spring boot·spring
Traving Yu14 分钟前
Spring源码与框架原理
java·后端·spring