从Cygwin呼叫liquibase命令行



尝试从命令行(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"

相关内容

  • 没有找到相关文章

最新更新