不能使用命令行运行 liquibase

2022-09-02 03:25:56

我想使用 liquibase,但是当我想让它使用命令行运行时,就会发生这种情况:

PS C:\Users\Ferid\Downloads\liquibase-3.6.0-bin> .\liquibase
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: ch/qos/logback/core/filter/Filter
    at java.lang.Class.getDeclaredMethods0(Native Method)
    at java.lang.Class.privateGetDeclaredMethods(Unknown Source)
    at java.lang.Class.privateGetMethodRecursive(Unknown Source)
    at java.lang.Class.getMethod0(Unknown Source)
    at java.lang.Class.getMethod(Unknown Source)
    at sun.launcher.LauncherHelper.validateMainClass(Unknown Source)
    at sun.launcher.LauncherHelper.checkAndLoadMain(Unknown Source)
 Caused by: java.lang.ClassNotFoundException: ch.qos.logback.core.filter.Filter
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 7 more

我尝试过 liquibase-3.6.1,现在 liquibase-3.6.0


答案 1

库文件夹中缺少一个必需的库。

请参阅下面的错误报告链接,其中其他用户遇到了相同的问题。

看起来 3.6.1 在 lib 文件夹中仍然缺少 slf4j-api-1.7.25,我仍然收到通过 cli 调用 liquibase 时出错。

您有三种选择:

  1. 自己获取图书馆 [这里]
  2. 等待修补后的版本(也许自己提交修复程序)。
  3. 恢复到旧版本(3.5.5 应该可以正常工作)

有关错误报告,请参阅此处:https://liquibase.jira.com/browse/CORE-3201


答案 2

必须将此库添加到类路径中:

在我的情况下,我正在使用Spring Boot liquibase集成,所以,这是我的lquibase配置build.gradle

buildscript {
    dependencies {
        classpath 'org.postgresql:postgresql:9.4.1211.jre7'
        classpath 'org.liquibase:liquibase-core:3.6.3'
        classpath "org.liquibase:liquibase-gradle-plugin:2.0.1"
    }
}

plugins {
    id 'org.springframework.boot' version '2.1.3.RELEASE'
    id 'java'
    id "org.liquibase.gradle" version "2.0.1"
}


dependencies {
    liquibaseRuntime 'org.postgresql:postgresql:9.4.1211.jre7'
    liquibaseRuntime 'org.liquibase:liquibase-core:3.6.3'
    liquibaseRuntime 'org.liquibase:liquibase-groovy-dsl:2.0.1'
    liquibaseRuntime 'ch.qos.logback:logback-core:1.2.3'
    liquibaseRuntime 'ch.qos.logback:logback-classic:1.2.3'
}

def changeLog = "$projectDir/src/main/db/changelog.xml"
liquibase {
    activities {
        main {
            changeLogFile changeLog
            url 'jdbc:postgresql://localhost:5431/postgres'
            username 'postgres'
            password 'postgres'
        }
    }
}

它是从 liquibase-gradle-plugin 中提取的


推荐