Springboot整合Flyway自动管理数据库变更
编辑
784
2022-12-09
以若依项目为例(v3.8.4)
1、 pom.xml(ruoyi) 引入依赖管理
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
<version>${flyway.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
2、 pom.xml(ruoyi-admin).xml引入依赖
<dependencies>
<dependency>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-core</artifactId>
</dependency>
</dependencies>
3、 resources目录下新建db/migration目录 来存放sql脚本
版本1.0.0中放入初始化sql脚本
版本1.0.1中放入测试脚本
# 创建flyway_test 并插入一条数据
DROP TABLE IF EXISTS `cpt_monitor`.`flyway_test`;
CREATE TABLE `cpt_monitor`.`flyway_test`
(
`id` int NOT NULL AUTO_INCREMENT,
`update_time` datetime NULL,
PRIMARY KEY (`id`)
);
insert into `cpt_monitor`.`flyway_test`
values (1, now());
4、 在application.yml
中配置
spring
flyway:
# 是否启用flyway
enabled: true
# 编码格式,默认UTF-8
encoding: UTF-8
# 当迁移发现数据库非空且存在没有元数据的表时,自动执行基准迁移,新建schema_version表
baseline-on-migrate: true
配置好数据库链接,空数据库即可。正常情况下此时启动 便会在数据中执行初始化sql 和 测试sql 两个版本按顺序,并自动生成flyway_schema_history
表来记录版本;
5、 若依项目(v3.8.4)还需要额外增加配置
主要是有两个地方用到了
@PostConstruct
注解,系统需要从数据库中加载配置信息,并且是构造bean后就执行,此时flaway的数据库配置加载还没执行,如果是第一次执行项目的话,数据库都还没有表结构信息,所以会报错。
此时可以考虑重写flyway自动配置,通过@Bean的方式添加,不采用默认的自动化配置,控制表信息的加载时机。更方便的,直接改这两个地方的加载时机就行了。
1 、找到这两个配置类,注释掉初始化;
- ruoyi-system中com.ruoyi.system.service.impl.SysDictTypeServiceImpl的字典信息缓存配置
- ruoyi-system中com.ruoyi.system.service.impl.SysConfigServiceImpl的redis参数缓存配置
SysDictTypeServiceImpl.java
/**
* 项目启动时,初始化字典到缓存
*/
/*
@PostConstruct
public void init() {
loadingDictCache();
}
*/
SysConfigServiceImpl.java
/**
* 项目启动时,初始化参数到缓存
*/
/* @PostConstruct
public void init() {
loadingConfigCache();
}*/
2. 在若依system模块中新建conf/RuntimeConfig
package com.ruoyi.system.config;
import com.ruoyi.system.service.impl.SysConfigServiceImpl;
import com.ruoyi.system.service.impl.SysDictTypeServiceImpl;
import org.springframework.context.ApplicationListener;
import org.springframework.context.event.ContextRefreshedEvent;
import org.springframework.stereotype.Component;
/**
* @Description 兼容flyway 把 项目初始化内容 改到这里初始化(改变加载时机)
* ruoyi-system中com.ruoyi.system.service.impl.SysDictTypeServiceImpl的字典信息缓存配置
* ruoyi-system中com.ruoyi.system.service.impl.SysConfigServiceImpl的redis参数缓存配置
* 参考 https://blog.csdn.net/qq_41885819/article/details/114970148
* @Author wxyShine
* @Date 2022/12/9 9:37
* @Email wxy@wxy97.com
*/
@Component
public class RuntimeConfig implements ApplicationListener<ContextRefreshedEvent> {
private final SysConfigServiceImpl sysConfigServiceImpl;
private final SysDictTypeServiceImpl sysDictTypeServiceImpl;
public RuntimeConfig(SysConfigServiceImpl sysConfigServiceImpl,
SysDictTypeServiceImpl sysDictTypeServiceImpl) {
this.sysConfigServiceImpl = sysConfigServiceImpl;
this.sysDictTypeServiceImpl = sysDictTypeServiceImpl;
}
/**
* 项目启动时,初始化参数
*/
@Override
public void onApplicationEvent(ContextRefreshedEvent contextRefreshedEvent) {
sysConfigServiceImpl.loadingConfigCache();
sysDictTypeServiceImpl.loadingDictCache();
}
}
此时已经整合完成。
配置Maven插件来使用Flyway
在pom.xml(ruoyi)中增加如下
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies>
<plugin>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-maven-plugin</artifactId>
<version>5.2.4</version>
<configuration>
<url>jdbc:mysql://localhost:3306/name</url>
<user>root</user>
<password>123456</password>
<locations>
<location>classpath:db/migration</location>
</locations>
</configuration>
</plugin>
配置好之后即可使用maven插件来进行操作
- 12
- 0
-
分享