FlywayException: невозможно проверить миграцию SQL в location: classpath:db/migration
Я пытаюсь начать использовать flyway с интеграцией maven, но не могу заставить его работать.
Я следую документации, кажется, очень просто, поэтому никаких странных вещей, похоже, не делается.
мой пом.в 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>
у меня есть каталог ресурсы / db / миграция/ без какой-либо миграции еще.
когда я выдаю flyway: информация о cygwin или cmd, я получил ошибку flyway:
$ 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] ------------------------------------------------------------------------
может поможешь мне с этим?
Thans много.
5 ответов
Это также происходит, если цель компиляции не выполняется перед вызовом flyway: migrate. На самом деле это включено в руководство по быстрому запуску. Он говорит:
mvn compile flyway: migrate
однако, если вы пропустите эту деталь и начнете просто звонить mvn flyway:migrate
, файл SQL не будет скопирован в целевой каталог (на самом деле целевой каталог даже не будет существовать), и вы получите эту загадочную ошибку.
ну, просто чтобы вы знали.
Я нашел проблему, это происходит, когда мы настраиваем flyway в нашей среде, но у нас нет никакой миграции для выполнения.
Он не должен отображать ошибку пути к классам, но, к счастью, он работает.
кстати, еще одна проблема, которую я нашел заключается в том, что после выполнения init если мы проверим с info ничего не отображается. И если мы добавим новую миграцию с V1 затем info не будет показывать, если мы не изменим его на V1_1
надеемся помочь
Я столкнулся с такой же проблемой. В моем случае у меня был сценарий миграции в неправильном каталоге, который вызвал проблему. Я перевел сценарий В1__создать_человек_таблица.sql в правый каталог на resources/db/ migration / и это сработало!!
Я столкнулся с той же проблемой. Но когда я obeserved журналы остро я нашел flywaydb ищет в папке db/migration для скрипта, но мой скрипт находится в db/migrate. Итак, после исправления пути из db/migrate в db / migration он работает!!.
вот глупая ошибка, которую я сделал, где я получил эту досадную ошибку:
убедитесь, что вы установили упаковку как jar
не pom
в своем пом.в XML. Тогда mvn install
и убедитесь, что у вас есть jar для этого проекта в папке M2, иначе вы получите эту ошибку, так как файл миграции не был скопирован и найден.