7

情况

我有一个模块化Spring Boot项目。作为数据库模式管理器,我想使用Flyway. 如前所述,该项目是模块化的。这是因为会有不同的配置使用不同的模块。这意味着,我想将与模块相关的所有内容打包到它的特定项目中。有了Flyway这个似乎没那么简单。

问题

我理想中的想象:

ApplicationA
|
|_Module1
|  |
|  |_db/migration
|       |
|       |_V1__InitModule1Tables
|       |_V2__MigrateSomeTable
|      
|_Module2
   |
   |_db/migration
        |
        |_V1__InitModule2Tables
        |_V2__MigrateSomeTable

每个模块独立定义自己的飞行脚本,因为它们无论如何都不知道彼此的存在。每个模块显然都需要在共享数据库中拥有自己的飞行路线历史记录表。这样整个系统就解耦了,配置下一个应用程序不会ApplicationB很麻烦。Module1Module3

好吧,我没有找到任何配置的可能性Flyway来达到这个解决方案。

我试过的

在每个模块中做这样的事情显然是一个坏主意,因为 bean 的初始化/执行顺序是相当随机的,导致当我需要它们用于其他配置时没有创建表。也显得凌乱。

@Configuration
public class Module1Config {

    @Autowired
    public void flyway(DataSource dataSource) {
    Flyway flyway = new Flyway();
    flyway.setBaselineOnMigrate(true);
    flyway.setTable(flyway.getTable() + "-module1");
    flyway.setDataSource(dataSource);
    flyway.migrate();
    }
}

我不认为我是第一个试图实现这一目标的人。我怎样才能达到所需的模块化Flyway配置?

*更新*

解决方案

以下解决方案以重复主题建议的方式工作,对我有用:

我在我的模块中创建了一个配置模板,base任何其他模块都可以使用它,因为它提供了日志记录和日志记录等全局功能。

public abstract class FlywayConfig {

    private final String moduleName;

    public FlywayConfig(String moduleName) {
    this.moduleName = moduleName;
    }

    private final String baseScriptLocation = "classpath:db.migration.";

    @Autowired
    public void migrate(DataSource dataSource) {
        Flyway flyway = new Flyway();
        flyway.setDataSource(dataSource);
        flyway.setSchemas(moduleName.toUpperCase());
        flyway.setLocations(baseScriptLocation + moduleName.toLowerCase());
        flyway.migrate();
    }
}

在每个模块中,我只是简单地扩展了这个配置类

@Configuration
public class BaseConfig extends FlywayConfig {

    public static final String MODULE_NAME = "base";

    public BaseConfig() {
    super(MODULE_NAME);
    }
}

而我将飞行路线脚本保存在db.migration.*MODULE_NAME*

4

1 回答 1

3

这里实际上只有两种可能的情况:

  1. 您的模块是完全独立的,数据库中属于不同模块的对象之间没有关系:每个模块使用单独的模式历史表。

  2. 您的模块确实具有与属于其他模块的对象相关的数据库对象:您现在实际上具有数据库的单个全局生命周期,因此应该为所有模块使用单个模式历史表。

有关模块化应用程序的更多信息:https ://speakerdeck.com/axelfontaine/majestic-modular-monoliths

于 2018-03-19T08:38:37.223 回答