【发布时间】:2018-05-27 07:55:17
【问题描述】:
我正在尝试在我的 JEE+WildFly 应用程序中启动时使用 liquibase。 启动 AS 时,liquibase 抛出 ChangeLogParseException:
09:41:40,602 ERROR [org.jboss.as.server] (management-handler-thread - 1) WFLYSRV0021: Deploy of deployment "bets.war" was rolled back with the following failure message:
{
"WFLYCTL0080: Failed services" => {"jboss.undertow.deployment.default-server.default-host./bets" => "java.lang.RuntimeException: java.lang.RuntimeException: liquibase.exception.ChangeLogParseException: :classpath/WEB-INF/db-changelog.xml does not exist
Caused by: java.lang.RuntimeException: java.lang.RuntimeException: liquibase.exception.ChangeLogParseException: :classpath/WEB-INF/db-changelog.xml does not exist
Caused by: java.lang.RuntimeException: liquibase.exception.ChangeLogParseException: :classpath/WEB-INF/db-changelog.xml does not exist
Caused by: liquibase.exception.ChangeLogParseException: :classpath/WEB-INF/db-changelog.xml does not exist"},
Liquibase 参数在 web.xml 中设置:
<!-- liquibase auto startup -->
<context-param>
<param-name>liquibase.changelog</param-name>
<param-value>:classpath/WEB-INF/db-changelog.xml</param-value>
</context-param>
<context-param>
<param-name>liquibase.datasource</param-name>
<param-value>java:jboss/datasources/BetsDS</param-value>
</context-param>
<context-param>
<param-name>liquibase.onerror.fail</param-name>
<param-value>true</param-value>
</context-param>
<context-param>
<param-name>liquibase.contexts</param-name>
<param-value>production</param-value>
</context-param>
<listener>
<listener-class>liquibase.integration.servlet.LiquibaseServletListener</listener-class>
</listener>
结构如下:
查看这里的主题,db-changelog 在 .war 包中:
已经尝试将 liquibase.changelog 的值重命名为 WEB-INF/db-changelog.xml 和 /WEB-INF/db-changelog.xml,还是一样。
【问题讨论】:
-
如何调用 Liquibase 并在代码中设置变更日志路径?
-
帖子已编辑
-
liquibase.changelog参数的值应为WEB-INF/db-changelog.xml或/WEB-INF/db-changelog.xml。 -
这两种方式也是错误的。已经试过了。
标签: java maven jakarta-ee liquibase liquibase-hibernate