【问题标题】:Flyway fails to detect new migration filesFlyway 无法检测到新的迁移文件
【发布时间】:2019-05-31 21:47:46
【问题描述】:

添加新的迁移文件后,我正尝试在我的项目中从 Gradle 运行 flywayMigrate 任务,但 Flyway 没有选择它。我得到这个输出:

Flyway Community Edition 5.2.4 by Boxfuse
Database: jdbc:postgresql://localhost:5432/mydb (PostgreSQL 10.6)
Successfully validated 6 migrations (execution time 00:00.105s)
Current version of schema "public": 5
Schema "public" is up to date. No migration necessary.

所以它检测到我有 6 次迁移,但它不执行我刚刚添加的新文件 (V6) 并坚持说架构是最新的,即使它是最新的不。

这是我的配置的样子:

{
    url = database_url
    user = database_user
    password = database_password
    driver = database_driver
    schemas = ["public"]
    locations = ["filesystem:shared/src/main/resources/db/migration"]
    table = "flyway_schema_history"
    sqlMigrationPrefix = "V"
    sqlMigrationSuffix = ".sql"
    placeholderPrefix = "\${"
    placeholderSuffix = "}"
    target = "5.1"
}

我检查了所有设置,一切正常,如果我删除所有表,它会拾取第一个 5 个迁移文件,但由于某种原因第 6 个没有被选中向上。 (我什至尝试添加第 7 个,但它也不起作用)

我尝试在第 6 个迁移文件中运行 sql,它运行正常,因此可能是 Flyway 存在问题。

如果我使用debug 标志运行,我可以看到它甚至会解析并从文件中读出 sql,但所有迁移都被过滤掉了。我做错了什么?

...
15:23:34.893 [DEBUG] [org.flywaydb.core.internal.sqlscript.SqlScript] Parsing V5__some_migration_5.sql ...
15:23:34.893 [DEBUG] [org.flywaydb.core.internal.sqlscript.SqlScript] Found statement at line 1: ...
...
15:23:34.894 [DEBUG] [org.flywaydb.core.internal.sqlscript.SqlScript] Parsing V6__some_migration_6.sql ...
15:23:34.894 [DEBUG] [org.flywaydb.core.internal.sqlscript.SqlScript] Found statement at line 1: ...
15:23:34.894 [DEBUG] [org.flywaydb.core.internal.scanner.Scanner] Filtering out resource: shared/src/main/resources/db/migration/V1__some_migration_1.sql (filename: V1__some_migration_1.sql)
15:23:34.895 [DEBUG] [org.flywaydb.core.internal.scanner.Scanner] Filtering out resource: shared/src/main/resources/db/migration/V2__some_migration_2.sql (filename: V2__some_migration_2.sql)
15:23:34.895 [DEBUG] [org.flywaydb.core.internal.scanner.Scanner] Filtering out resource: shared/src/main/resources/db/migration/V3__some_migration_3.sql (filename: V3__some_migration_3.sql)
15:23:34.895 [DEBUG] [org.flywaydb.core.internal.scanner.Scanner] Filtering out resource: shared/src/main/resources/db/migration/V4__some_migration_4.sql (filename: V4__some_migration_4.sql)
15:23:34.895 [DEBUG] [org.flywaydb.core.internal.scanner.Scanner] Filtering out resource: shared/src/main/resources/db/migration/V5__some_migration_5.sql (filename: V5__some_migration_5.sql)
15:23:34.895 [DEBUG] [org.flywaydb.core.internal.scanner.Scanner] Filtering out resource: shared/src/main/resources/db/migration/V6__some_migration_6.sql (filename: V6__some_migration_6.sql)
15:23:34.899 [DEBUG] [org.postgresql.jdbc.PgConnection]   setAutoCommit = true
15:23:34.899 [INFO] [org.flywaydb.core.internal.command.DbValidate] Successfully validated 6 migrations (execution time 00:00.016s)
15:23:34.899 [DEBUG] [org.postgresql.jdbc.PgConnection]   setAutoCommit = false
15:23:34.899 [DEBUG] [org.flywaydb.core.internal.command.DbSchemas] Schema "public" already exists. Skipping schema creation.
15:23:34.900 [DEBUG] [org.postgresql.jdbc.PgConnection]   setAutoCommit = true
15:23:34.915 [INFO] [org.flywaydb.core.internal.command.DbMigrate] Current version of schema "public": 5
15:23:34.915 [INFO] [org.flywaydb.core.internal.command.DbMigrate] Schema "public" is up to date. No migration necessary.

我在flyway_schema_history 中看到的与日志所说的一致:

installed_rank  version description type    script  checksum    installed_by    installed_on    execution_time  success
1   1   some migration 1    SQL V1__some_migration_1.sql    1640479949  myuser  2019-05-31 15:17:19.354850  26  true
2   2   some migration 2    SQL V2__some_migration_2.sql    1463373644  myuser  2019-05-31 15:17:19.394065  1   true
3   3   some migration 3    SQL V3__some_migration_3.sql    1872028758  myuser  2019-05-31 15:17:19.398957  9   true
4   4   some migration 4    SQL V4__some_migration_4.sql    762610066   myuser  2019-05-31 15:17:19.410718  5   true
5   5   some migration 5    SQL V5__some_migration_5.sql    -355256115  myuser  2019-05-31 15:17:19.418077  1   true

【问题讨论】:

  • 所有迁移文件都遵循命名方案吗?
  • flayway_history 表中有什么?
  • 我编辑了我的问题。
  • 真的很奇怪...看看这里-可能是,这个解决方案提供了一些想法...stackoverflow.com/questions/43300233/…
  • 这是不同的。我也尝试使用--stacktrace 运行,但没有任何异常。

标签: java gradle flyway


【解决方案1】:

:-)

你的配置中有target = "5.1",但是

target  NO  latest version  

The target version up to which Flyway should run migrations. 
Migrations with a higher version number will not be applied. 
The string 'current' will be interpreted as MigrationVersion.CURRENT, 
a placeholder for the latest version that has been applied to the database. 

Gradle Task: flywayMigrate

这就是您无法处理迁移的原因 > 5.1

【讨论】:

  • @Hexworks 有时会发生 :-) 我也很想知道。请把答案标记为解决方案。祝你有美好的一天。
猜你喜欢
  • 2017-12-11
  • 2019-04-28
  • 2015-07-10
  • 2012-02-07
  • 2021-02-21
  • 2012-11-17
  • 2014-05-14
  • 2018-06-27
  • 2021-01-03
相关资源
最近更新 更多