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 中的多个数据源,[重复]