spring boot 中的多个 liquibase 配置

Posted

技术标签:

【中文标题】spring boot 中的多个 liquibase 配置【英文标题】:Multiple liquibase configurations in spring boot 【发布时间】:2017-09-06 20:22:04 【问题描述】:

我有使用 2 个数据库的 spring boot 应用程序。我定义了 2 个提供指定数据源的配置。我想让这些数据源由 liquibase 单独管理。我定义了 2 个单独的变更日志文件。

问题是我无法为 liquibase 定义 2 个单独的 bean。

这是我的配置类:

...
public class CCSConfiguration 
    ...

    @Bean
    @ConfigurationProperties("ccs.liquibase")
    public LiquibaseProperties ccsLiquibaseProperties() 
        return new LiquibaseProperties();
    

    @Bean
    public SpringLiquibase ccsLiquibase(LiquibaseProperties liquibaseProperties) 
        ...
    
    ...




...
public class CCAConfiguration 
    ...
    @ConfigurationProperties("cca.liquibase")
    public LiquibaseProperties ccaLiquibaseProperties() 
        return new LiquibaseProperties();
    

    @Bean
    public SpringLiquibase ccaLiquibase(LiquibaseProperties liquibaseProperties) 
        ...
    
    ...

和属性:

cca:
    liquibase:
        change-log: classpath:config/liquibase/cca/master.xml
ccs:
    liquibase:
        change-log: classpath:config/liquibase/ccs/master.xml

使用此配置,我在运行应用程序时遇到以下错误:

2017-04-11 14:26:55.664  WARN 34292 --- [  restartedMain] ationConfigEmbeddedWebApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'liquibase' available
2017-04-11 14:26:55.711  WARN 34292 --- [  restartedMain] o.s.boot.SpringApplication               : Error handling failed (Error creating bean with name 'delegatingApplicationListener' defined in class path resource [org/springframework/security/config/annotation/web/configuration/WebSecurityConfiguration.class]: BeanPostProcessor before instantiation of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.cache.config.internalCacheAdvisor' defined in class path resource [org/springframework/cache/annotation/ProxyCachingConfiguration.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.springframework.cache.interceptor.BeanFactoryCacheOperationSourceAdvisor]: Factory method 'cacheAdvisor' threw exception; nested exception is java.lang.NullPointerException)
2017-04-11 14:26:55.939 ERROR 34292 --- [  restartedMain] o.s.b.d.LoggingFailureAnalysisReporter   : 

***************************
APPLICATION FAILED TO START
***************************

Description:

A component required a bean named 'liquibase' that could not be found.


Action:

Consider defining a bean named 'liquibase' in your configuration.

那么,是否可以为不同的数据源定义多个 liquibase bean?

【问题讨论】:

【参考方案1】:

有两种选择:

    您定义了一个名为 liquibase 的 bean,让 spring-boot 集成过程在您的第一个 DS 上更新您的模式。你必须手动处理第二个

    在启动时禁用 liquibase 自动更新

启用:假

并定义您的方式 DS 和 liquibase bean 来更新您的两个数据库

【讨论】:

事实证明,第一个 bean 必须有名称“liiquibase”,第二个可以有任何不同的名称。而且它有效! 可能与github.com/spring-projects/spring-boot/issues/17802有关。

以上是关于spring boot 中的多个 liquibase 配置的主要内容,如果未能解决你的问题,请参考以下文章

带有 Spring Boot 的 Spring Data JPA 中的多个数据源,[重复]

spring boot 中的多个 liquibase 配置

Spring Boot 中的多个 SQL 导入文件

在 Spring Boot 中的多个包上使用 @ComponentScan 时出错

部署多个Spring Boot 项目异常

Spring Boot - 如何为指定根目录中的多个路由提供一个静态 html 文件