【问题标题】:FlyWay migrate scriptsFlyWay 迁移脚本
【发布时间】:2018-02-28 11:55:44
【问题描述】:

你能帮忙解释为什么flyway不能安装脚本吗 ?

我的架构是空的,只有一个创建 flyway 的表。但它也是空的。

如何正确配置 FlyWay?我的脚本有以下形式

V1__20170918_Initial_structure.sql

18:43:30,773 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG Flyway:40 - DDL Transactions Supported: false
18:43:30,773 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG Flyway:40 - Schema: TEST_SERVER
18:43:30,778 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG FeatureDetector:40 - Spring Jdbc available: false
18:43:30,779 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG SqlScriptFlywayCallback:40 - Scanning for SQL callbacks ...
18:43:30,779 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning for classpath resources at 'classpath:db/migration' (Prefix: '', Suffix: '.sql')
18:43:30,780 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Determining location urls for classpath:db/migration using ClassLoader ModuleClassLoader for Module "deployment.mobile.bank.services-1.0.5.ear.flyway-1.0-SNAPSHOT.jar:main" from Service Module Loader ...
18:43:30,780 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning URL: vfs:/E:/Soft/Server_10.1.0/bin/content/mobile.bank.services-1.0.5.ear/flyway-1.0-SNAPSHOT.jar/db/migration/
18:43:30,780 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG FeatureDetector:40 - JBoss VFS v2 available: false
18:43:30,781 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG FeatureDetector:40 - JBoss VFS v3 available: true
18:43:30,782 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG JBossVFSv3ClassPathLocationScanner:40 - Scanning starting at classpath root on JBoss VFS: E:\Soft\Server_10.1.0\bin\content\mobile.bank.services-1.0.5.ear\flyway-1.0-SNAPSHOT.jar\/
18:43:30,834 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG DbValidate:40 - Validating migrations ...
18:43:30,836 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning for classpath resources at 'classpath:db/migration' (Prefix: 'V', Suffix: '.sql')
18:43:30,836 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning URL: vfs:/E:/Soft/Server_10.1.0/bin/content/mobile.bank.services-1.0.5.ear/flyway-1.0-SNAPSHOT.jar/db/migration/
18:43:30,836 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG FeatureDetector:40 - JBoss VFS v2 available: false
18:43:30,836 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning for classpath resources at 'classpath:db/migration' (Prefix: 'R', Suffix: '.sql')
18:43:30,836 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning URL: vfs:/E:/Soft/Server_10.1.0/bin/content/mobile.bank.services-1.0.5.ear/flyway-1.0-SNAPSHOT.jar/db/migration/
18:43:30,837 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG FeatureDetector:40 - JBoss VFS v2 available: false
18:43:30,837 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning for classes at 'classpath:db/migration' (Implementing: 'org.flywaydb.core.api.migration.jdbc.JdbcMigration')
18:43:30,837 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG ClassPathScanner:40 - Scanning URL: vfs:/E:/Soft/Server_10.1.0/bin/content/mobile.bank.services-1.0.5.ear/flyway-1.0-SNAPSHOT.jar/db/migration/
18:43:30,838 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG FeatureDetector:40 - JBoss VFS v2 available: false
18:43:30,853 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 INFO  DbValidate:44 - Successfully validated 0 migrations (execution time 00:00.018s)
18:43:30,859 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG DbSchemas:40 - Schema "TEST_SERVER" already exists. Skipping schema creation.
18:43:30,935 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG Table:40 - Locking table "TEST_SERVER"."SERVER_VERSION_DB"...
18:43:30,936 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 DEBUG Table:40 - Lock acquired for table "TEST_SERVER"."SERVER_VERSION_DB"
18:43:30,943 INFO  [stdout] (ServerService Thread Pool -- 20) 2017-09-19 18:43:30 DEBUG Reflections:184 - going to scan these urls:
18:43:30,943 INFO  [stdout] (ServerService Thread Pool -- 20) vfs:/E:/Soft/Server_10.1.0/bin/content/mobile.bank.services-1.0.5.ear/service-web-1.0-SNAPSHOT.war/WEB-INF/classes/
18:43:30,943 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 INFO  DbMigrate:44 - Current version of schema "TEST_SERVER": << Empty Schema >>
18:43:30,945 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 INFO  DbMigrate:44 - Schema "TEST_SERVER" is up to date. No migration necessary.
18:43:30,974 INFO  [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 INFO  DEBUG_LOGGER:48 - FlyWayMigrator - flywayMigrateStop

我的源代码

public void flywayMigrateStart() {
    LoggerUtil.getDEBUG_LOGGER().info("FlyWayMigrator - flywayMigrateStart");
    String flywayMinVersion = FlyWayProperty.getInstance().getProperty(FlyWayProperty.FLYWAY_MIN_VERSION);

    if (flywayMinVersion != null) {
        Flyway flyway = new Flyway();
        try {
            flyway.setDataSource(createDataSource());
            flyway.setTable(FlyWayProperty.getInstance().getProperty(FlyWayProperty.FLYWAY_MIGRATION_TABLE_NAME));
            flyway.setBaselineVersionAsString(FlyWayProperty.getInstance().getProperty(FlyWayProperty.FLYWAY_BASELINE_VERSION));
            flyway.setSqlMigrationSeparator(FlyWayProperty.getInstance().getProperty(FlyWayProperty.FLYWAY_MIGRATION_SEPARATOR));
            flyway.setEncoding(FlyWayProperty.getInstance().getProperty(FlyWayProperty.FLYWAY_ENCODING));
            flyway.setSchemas(FlyWayProperty.getInstance().getProperty(FlyWayProperty.ORACLE_DB_USERNAME));
            flyway.setBaselineOnMigrate(true);
            flyway.migrate();
            flywayMigrateStop();
        } catch (Exception e) {
            throw new RuntimeException(e.getMessage(), e);
        }
    }
}

我的属性文件

ORACLE_DB_DRIVER_CLASS=oracle.jdbc.driver.OracleDriver
ORACLE_DB_URL=jdbc:oracle:thin:@192.168.100.210:1521:DB
ORACLE_DB_USERNAME=TEST_SERVER
ORACLE_DB_PASSWORD=TEST_SERVER
FLYWAY_MIN_VERSION=V1
FLYWAY_MIGRATION_TABLE_NAME=SERVER_VERSION_DB
FLYWAY_BASELINE_VERSION=1.0.0
FLYWAY_MIGRATION_SEPARATOR=#
FLYWAY_ENCODING=UTF-8

【问题讨论】:

  • 需要更多信息。
  • 什么不工作?这些日志声明表明 Flyway 认为不需要迁移。 18:43:30,945 INFO [stdout] (ServerService Thread Pool -- 14) 2017-09-19 18:43:30 INFO DbMigrate:44 - Schema "TEST_SERVER" is up to date. No migration necessary.
  • 我添加了一些信息
  • @BobKuhar 有两个脚本没有执行。该方案完全是空的。

标签: java flyway


【解决方案1】:

Flyway 找不到您的迁移文件,因此它认为一切都是最新的:

INFO  DbValidate:44 - Successfully validated 0 migrations (execution time 00:00.018s)

您需要指定一个位置或将您的迁移移动到它已经在搜索的位置。使用setLocations() 这样做。

【讨论】:

    【解决方案2】:

    如果您使用 maven 构建此 jar - flyway-1.0-SNAPSHOT.jar,请确保 src/main/resources 有一个包含您的 V1__20170918_Initial_structure.sql 的 db/migration 文件夹

    如果它能够解决您的问题,请告诉我。

    【讨论】:

      猜你喜欢
      • 2011-11-05
      • 2020-08-17
      • 2016-03-12
      • 2021-11-22
      • 2017-03-16
      • 1970-01-01
      • 2016-06-05
      • 2017-05-21
      • 2017-01-03
      相关资源
      最近更新 更多