在Spring Boot应用程序中使用Flyway进行多个数据源迁移

我们在基于Spring

Boot的应用程序中使用Flyway进行数据库迁移,现在我们需要在使用多个数据源策略的同时引入多租户支持。作为其中的一部分,我们还需要支持多个数据源的迁移。所有数据源都应保持相同的结构,因此应使用相同的迁移脚本来迁移所有数据源。另外,迁移应该在应用程序启动时进行(与构建时间相反,而似乎可以将Maven插件配置为迁移多个数据源)。为了达到此目的,最好的方法是什么?该应用程序已经定义了数据源bean,但是Flyway仅对主要数据源执行迁移。

回答:

Flyway支持使用Java编码的迁移,因此您可以在应用程序启动期间启动Flyway。

https://flywaydb.org/documentation/migration/java

我不确定如何将Flyway配置为通过其配置文件来定位多个数据源。我自己的开发基于使用Java对每个需要使用的数据源调用一次Flyway。Spring

Boot支持标记为的bean的自动装配@FlywayDataSource,但是我还没有研究如何使用它。

对于Java解决方案,代码可以简单到

    Flyway flyway = new Flyway();

// Set the data source

flyway.setDataSource(dataSource);

// Where to search for classes to be executed or SQL scripts to be found

flyway.setLocations("net.somewhere.flyway");

flyway.setTarget(MigrationVersion.LATEST);

flyway.migrate();

以上是 在Spring Boot应用程序中使用Flyway进行多个数据源迁移 的全部内容, 来源链接: utcz.com/qa/435814.html

回到顶部