为 Liquibase 任务添加 Gradle 个任务
Add Gradle Tasks for Liquibase Tasks
我正在使用带有 Gradle 的 JHipster 4.5.4 作为构建系统,并希望添加 Gradle 任务来执行 Liquibase 任务,例如验证或重置。我使用 JHipster 附带的 liquibaseDiffChangelog 任务作为模板。这个任务是这样定义的:
task liquibaseDiffChangelog(dependsOn: compileJava, type: JavaExec) {
group = "liquibase"
if (OperatingSystem.current().isWindows()) {
dependsOn pathingLiquibaseJar
doFirst {
classpath = files(pathingLiquibaseJar.archivePath)
}
} else {
classpath sourceSets.main.runtimeClasspath
classpath configurations.liquibase
}
main = "liquibase.integration.commandline.Main"
args "--changeLogFile=src/main/resources/config/liquibase/changelog/" + buildTimestamp() +"_changelog.xml"
args "--referenceUrl=hibernate:spring:at.project.domain?dialect=org.hibernate.dialect.MySQL5InnoDBDialect&hibernate.physical_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy&hibernate.implicit_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringImplicitNamingStrategy"
args "--username=testapp_db_user"
args "--password=secret"
args "--url=jdbc:mysql://localhost:3306/testapp_db"
args "--driver=com.mysql.jdbc.Driver"
args "diffChangeLog"
}
我开始只是简单地用 validate 交换 diffChangeLog,但随后收到类路径错误。我还添加了一个类路径参数,并以这样的任务定义结束:
task liquibaseValidate(dependsOn: compileJava, type: JavaExec) {
group = "liquibase"
if (OperatingSystem.current().isWindows()) {
dependsOn pathingLiquibaseJar
doFirst {
classpath = files(pathingLiquibaseJar.archivePath)
}
} else {
classpath sourceSets.main.runtimeClasspath
classpath configurations.liquibase
}
main = "liquibase.integration.commandline.Main"
args "--changeLogFile=./build/resources/main/config/liquibase/master.xml"
args "--referenceUrl=hibernate:spring:at.project.domain?dialect=org.hibernate.dialect.MySQL5InnoDBDialect&hibernate.physical_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy&hibernate.implicit_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringImplicitNamingStrategy"
args "--username=testapp_db_user"
args "--password=secret"
args "--url=jdbc:mysql://localhost:3306/testapp_db"
args "--driver=com.mysql.jdbc.Driver"
args "--classpath=./build/resources/main/config/liquibase/changelog/"
args "validate"
}
读取了主文件,因为它提到了正确的文件名,所以这部分没问题。但它无法识别 master.xml 文件中引用的实际变更集文件的路径。
这是错误消息:
19:51:04.292 [main] ERROR liquibase - classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
liquibase.exception.ChangeLogParseException: liquibase.exception.SetupException: classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
at liquibase.parser.core.xml.AbstractChangeLogParser.parse(AbstractChangeLogParser.java:27)
at liquibase.Liquibase.getDatabaseChangeLog(Liquibase.java:229)
at liquibase.Liquibase.validate(Liquibase.java:1443)
at liquibase.integration.commandline.Main.doMigration(Main.java:1102)
at liquibase.integration.commandline.Main.run(Main.java:188)
at liquibase.integration.commandline.Main.main(Main.java:103)
Caused by: liquibase.exception.SetupException: classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
at liquibase.changelog.DatabaseChangeLog.handleChildNode(DatabaseChangeLog.java:322)
at liquibase.changelog.DatabaseChangeLog.load(DatabaseChangeLog.java:282)
at liquibase.parser.core.xml.AbstractChangeLogParser.parse(AbstractChangeLogParser.java:25)
... 5 common frames omitted
Caused by: liquibase.exception.ChangeLogParseException: classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
at liquibase.parser.core.xml.XMLChangeLogSAXParser.parseToNode(XMLChangeLogSAXParser.java:100)
at liquibase.parser.core.xml.AbstractChangeLogParser.parse(AbstractChangeLogParser.java:17)
at liquibase.changelog.DatabaseChangeLog.include(DatabaseChangeLog.java:478)
at liquibase.changelog.DatabaseChangeLog.handleChildNode(DatabaseChangeLog.java:320)
... 7 common frames omitted
如何正确添加类路径?
与 this JHipster issue 相关,您需要从 master.xml(位于 src/main/resources/config/liquibase/master.xml
)中的更新日志路径中删除 classpath:
。这将使您可以使用 liquibaseDiffChangeLog 以外的其他 liquibase 任务。这应该在下一个版本 (v4.6.2+) 中修复。
我正在使用带有 Gradle 的 JHipster 4.5.4 作为构建系统,并希望添加 Gradle 任务来执行 Liquibase 任务,例如验证或重置。我使用 JHipster 附带的 liquibaseDiffChangelog 任务作为模板。这个任务是这样定义的:
task liquibaseDiffChangelog(dependsOn: compileJava, type: JavaExec) {
group = "liquibase"
if (OperatingSystem.current().isWindows()) {
dependsOn pathingLiquibaseJar
doFirst {
classpath = files(pathingLiquibaseJar.archivePath)
}
} else {
classpath sourceSets.main.runtimeClasspath
classpath configurations.liquibase
}
main = "liquibase.integration.commandline.Main"
args "--changeLogFile=src/main/resources/config/liquibase/changelog/" + buildTimestamp() +"_changelog.xml"
args "--referenceUrl=hibernate:spring:at.project.domain?dialect=org.hibernate.dialect.MySQL5InnoDBDialect&hibernate.physical_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy&hibernate.implicit_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringImplicitNamingStrategy"
args "--username=testapp_db_user"
args "--password=secret"
args "--url=jdbc:mysql://localhost:3306/testapp_db"
args "--driver=com.mysql.jdbc.Driver"
args "diffChangeLog"
}
我开始只是简单地用 validate 交换 diffChangeLog,但随后收到类路径错误。我还添加了一个类路径参数,并以这样的任务定义结束:
task liquibaseValidate(dependsOn: compileJava, type: JavaExec) {
group = "liquibase"
if (OperatingSystem.current().isWindows()) {
dependsOn pathingLiquibaseJar
doFirst {
classpath = files(pathingLiquibaseJar.archivePath)
}
} else {
classpath sourceSets.main.runtimeClasspath
classpath configurations.liquibase
}
main = "liquibase.integration.commandline.Main"
args "--changeLogFile=./build/resources/main/config/liquibase/master.xml"
args "--referenceUrl=hibernate:spring:at.project.domain?dialect=org.hibernate.dialect.MySQL5InnoDBDialect&hibernate.physical_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy&hibernate.implicit_naming_strategy=org.springframework.boot.orm.jpa.hibernate.SpringImplicitNamingStrategy"
args "--username=testapp_db_user"
args "--password=secret"
args "--url=jdbc:mysql://localhost:3306/testapp_db"
args "--driver=com.mysql.jdbc.Driver"
args "--classpath=./build/resources/main/config/liquibase/changelog/"
args "validate"
}
读取了主文件,因为它提到了正确的文件名,所以这部分没问题。但它无法识别 master.xml 文件中引用的实际变更集文件的路径。 这是错误消息:
19:51:04.292 [main] ERROR liquibase - classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
liquibase.exception.ChangeLogParseException: liquibase.exception.SetupException: classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
at liquibase.parser.core.xml.AbstractChangeLogParser.parse(AbstractChangeLogParser.java:27)
at liquibase.Liquibase.getDatabaseChangeLog(Liquibase.java:229)
at liquibase.Liquibase.validate(Liquibase.java:1443)
at liquibase.integration.commandline.Main.doMigration(Main.java:1102)
at liquibase.integration.commandline.Main.run(Main.java:188)
at liquibase.integration.commandline.Main.main(Main.java:103)
Caused by: liquibase.exception.SetupException: classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
at liquibase.changelog.DatabaseChangeLog.handleChildNode(DatabaseChangeLog.java:322)
at liquibase.changelog.DatabaseChangeLog.load(DatabaseChangeLog.java:282)
at liquibase.parser.core.xml.AbstractChangeLogParser.parse(AbstractChangeLogParser.java:25)
... 5 common frames omitted
Caused by: liquibase.exception.ChangeLogParseException: classpath:config/liquibase/changelog/00000000000000_initial_schema.xml does not exist
at liquibase.parser.core.xml.XMLChangeLogSAXParser.parseToNode(XMLChangeLogSAXParser.java:100)
at liquibase.parser.core.xml.AbstractChangeLogParser.parse(AbstractChangeLogParser.java:17)
at liquibase.changelog.DatabaseChangeLog.include(DatabaseChangeLog.java:478)
at liquibase.changelog.DatabaseChangeLog.handleChildNode(DatabaseChangeLog.java:320)
... 7 common frames omitted
如何正确添加类路径?
与 this JHipster issue 相关,您需要从 master.xml(位于 src/main/resources/config/liquibase/master.xml
)中的更新日志路径中删除 classpath:
。这将使您可以使用 liquibaseDiffChangeLog 以外的其他 liquibase 任务。这应该在下一个版本 (v4.6.2+) 中修复。