我正在尝试使用maven集成的flyway,但无法使其正常工作。
我关注文档似乎非常简单,所以似乎没有什么奇怪的事情可以做。
我的 pom.xml 如下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.test</groupId>
<artifactId>test</artifactId>
<version>0.0.1-SNAPSHOT</version>
<build>
<plugins>
<!-- Flyway plugin configuration -->
<plugin>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-maven-plugin</artifactId>
<version>3.0</version>
<configuration>
<url>jdbc:mysql://localhost:3306/test</url>
<user>test_fede</user>
<password>test_fede</password>
</configuration>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.21</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>13.0.1</version>
</dependency>
<!-- DB dependencies -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.21</version>
</dependency>
<!-- Test dependencies -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.1</version>
<scope>compile</scope>
</dependency>
</dependencies>
</project>
我的目录 resources / db / migration / 没有任何迁移。
当我发出flyway:关于cygwin或cmd的信息时,我遇到了飞路错误:
$ mvn compile flyway:info
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Building Unnamed - com.test:test:jar:0.0.1-SNAPSHOT
[INFO] task-segment: [compile, flyway:info]
[INFO] ------------------------------------------------------------------------
[INFO] [resources:resources {execution: default-resources}]
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] Copying 0 resource
[INFO] [compiler:compile {execution: default-compile}]
[INFO] Nothing to compile - all classes are up to date
[INFO] [flyway:info {execution: default-cli}]
[INFO] Database: jdbc:mysql://localhost:3306/test (MySQL 5.5)
[INFO] ------------------------------------------------------------------------
[ERROR] BUILD ERROR
[INFO] ------------------------------------------------------------------------
[INFO] org.flywaydb.core.api.FlywayException: Unable to scan for SQL migrations in location: classpath:db/migration
Embedded error: Unable to determine URL for classpath location: db/migration (ClassLoader: org.codehaus.classworlds.RealmClassLoader@5bcdbf6)
[INFO] ------------------------------------------------------------------------
[INFO] For more information, run Maven with the -e switch
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1 second
[INFO] Finished at: Tue May 06 11:06:15 CST 2014
[INFO] Final Memory: 17M/223M
[INFO] ------------------------------------------------------------------------
能帮我个忙吗?
很多。
答案 0 :(得分:15)
如果在调用flyway:migrate之前未执行编译目标,也会发生这种情况。实际上,这包括在快速入门手册中。它说:
mvn 编译 flyway:migrate
但是,如果你错过了这个细节并开始只调用mvn flyway:migrate
,那么SQL文件将不会被复制到目标目录中(实际上目标目录甚至不存在),你会得到这个神秘的错误。
答案 1 :(得分:10)
嗯,只是为了让你知道。
我发现了问题,当我们在环境中设置flyway但我们没有任何迁移要执行时就会发生。
它不应该显示类路径错误,但幸运的是它正在工作。
顺便说一句,我发现的另一个问题是,如果我们检查信息,执行 init 后,就不会显示任何内容。如果我们使用 V1 添加新迁移,则除非我们将其更改为 V1_1 ,否则信息将无法显示
希望能提供帮助
答案 2 :(得分:4)
我遇到了同样的问题。在我的情况下,我的迁移脚本在错误的目录中导致了问题。我将脚本V1__Create_person_table.sql移动到资源/ db / migration /的正确目录,并且它工作正常!!
答案 3 :(得分:2)
我遇到了同样的问题。但当我仔细观察日志时,我发现flywaydb正在查找脚本的db / migration文件夹,但我的脚本在db / migrate中。所以,在纠正从db / migrate到db / migration的路径后,它可以工作!!。
答案 4 :(得分:1)
我有一个类似的问题,这是因为当我创建迁移目录时,我直接给它命名为db.migration
。
通过创建目录db
,然后在其中运行它的migration
目录。
答案 5 :(得分:0)
在我遇到这个令人讨厌的错误的地方,这是一个愚蠢的错误:
确保在 pom.xml 中将包装设置为jar
而不是pom
。然后mvn install
并确保在M2文件夹中有一个jar项目,否则您将收到此错误,因为迁移文件未被复制并找到。
答案 6 :(得分:0)
我也有类似的问题。就我而言,我以为我在对所有内容进行了三重检查后都正确命名了目录。原来我键入的是migrations
而不是migration
。我一解决这个问题,一切都很好。
在此之前,迁移文件名中的版本标记(V1)之后,下划线存在另一个问题。它必须是dunder(双下划线),因此始终为V1__description.sql
。
我遇到的所有飞行问题似乎都不是大问题。它总是很小的东西,很容易修复。这只是要找出问题所在。那是困难的部分。