尝试从命令行(bash脚本)运行对liquibase的调用。如果我在服务器(Red hat linux)上运行它,这是有效的,但如果我从cygwin提示符运行它,我会得到一个错误:
java -cp ../liquibase-core-3.1.1:../ojdbc6-11.2.0.3.jar liquibase.integration.commandline.Main --driver=oracle.jdbc.OracleDriver
--changeLogFile=database/master.xml --url=${schema_url} --username=${schema_username} --password=${schema_password}
--contexts=${schema_context} migrate
我得到错误:
Error: Could not find or load main class liquibase.integration.commandline.Main
不明白为什么。
找到了解决问题的方法。创建了一个包含信息的liquibase.properties文件,
url: <url>
username: <username>
password: <password>
contexts: global,dev
driver: oracle.jdbc.OracleDriver
classpath: ../ojdbc6-11.2.0.3.jar
changeLogFile: database/master.xml
并使用调用liquibase CLI
java -jar ../liquibase-core-3.1.1.jar --defaultsFile=../foo/fum/liquibase.properties migrate
这在服务器和cygwin上都运行良好。
这个问题的出现是因为Java需要一个windows风格的路径,而liquibase脚本发出的是unix风格的路径。另请参阅关于如何从cygwin运行Java的讨论。建议的解决方案是通过cygpath来修复它。
不过,根本情况有所不同。如果你查看liquibase的启动脚本,你会看到以下代码
# build classpath from all jars in lib
if [ -f /usr/bin/cygpath ]; then
CP=.
for i in "$LIQUIBASE_HOME"/liquibase*.jar; do
i=`cygpath --windows "$i"`
CP="$CP;$i"
done
for i in "$LIQUIBASE_HOME"/lib/*.jar; do
i=`cygpath --windows "$i"`
CP="$CP;$i"
done
else
if [[ $(uname) = MINGW* ]]; then
CP_SEPARATOR=";"
else
CP_SEPARATOR=":"
fi
CP=.
for i in "$LIQUIBASE_HOME"/liquibase*.jar; do
CP="$CP""$CP_SEPARATOR""$i"
done
for i in "$LIQUIBASE_HOME"/lib/*.jar; do
CP="$CP""$CP_SEPARATOR""$i"
done
fi
这就是脚本检查cygpath的存在,如果发现问题,就会修复它。很可能你缺少cygpath。
如果which cygpath
导致/usr/bin/cygpath
,那么一切都应该按预期工作。否则,您已找到根本原因。
这就提出了为什么缺少cygpath以及如何获取它的问题。在我的案例中,我删除了git/gitbash的(过时的)安装,并安装了最新版本。它附带了一个最新的gitbash,根据需要包含cygpath。
问题是CYGWIN上的Java在解决路径方面存在问题。要进行此操作,请添加
cygwinpath -wp
要解决此问题,请更换
java -cp ../liquibase-core-3.1.1:../ojdbc6-11.2.0.3.jar
带有
java -classpath `cygpath -wp ../liquibase-core-3.1.1:../ojdbc6-11.2.0.3.jar`
请记住用以下标记包围cygwint -wp <path>
`
检查主中的主类jar文件"liquibase.jar"