首页 文章

从属性文件加载数据,以供Liquibase在Maven构建中使用

提问于
浏览
6

我可以通过maven build( liquibase:update goal)运行Liquibase changelog而不会有任何问题 . 现在,我希望Liquibase使用数据库凭据和从属性文件(db.properties)加载的URL,具体取决于所选的Maven配置文件:

|-- pom.xml
`-- src
    `-- main
        `-- resources
            |-- local
            |   `-- db.properties
            |-- dev
            |   `-- db.properties
            |-- prod
            |   `-- db.properties
            `-- db-changelog-master.xml
            `-- db-changelog-1.0.xml

3个属性文件中的每一个都如下所示:

database.driver = oracle.jdbc.driver.OracleDriver
database.url = jdbc:oracle:thin:@<host_name>:<port_number>/instance
database.username = user
database.password = password123

现在,不是在POM文件本身中定义这些属性(如此问题的接受答案liquibase using maven with two databases does not work中所述),我希望它们从外部属性文件加载 . 我试过不同的方法无济于事:

1. I used Maven's resource element in the POM file:

<build>
      <pluginManagement>
         <plugins>
            <plugin>
               <groupId>org.liquibase</groupId>
               <artifactId>liquibase-maven-plugin</artifactId>
               <version>3.1.0</version>
               <configuration>
                  <changeLogFile>db.changelog-master.xml</changeLogFile>
                  <verbose>true</verbose>
               </configuration>
            </plugin>
         </plugins>
      </pluginManagement>
   </build>


<profiles>
    <profile>
        <id>local</id>
        <activation>
            <activeByDefault>true</activeByDefault>
        </activation>
        <build>
            <resources>
                <resource>
                    <directory>src/main/resources/local</directory>
                </resource>
            </resources>
        </build>
        <properties>
            <liquibase.url>${database.url}</liquibase.url>
            <liquibase.driver>${database.driver}</liquibase.driver>
            <liquibase.username>${database.username}</liquibase.username>
            <liquibase.password>${database.password}</liquibase.password>
        </properties>
    </profile>
    <profile>
        <id>dev</id>
        <build>
            <resources>
                <resource>
                    <directory>src/main/resources/dev</directory>
                </resource>
            </resources>
        </build>
        <properties>
            <liquibase.url>${database.url}</liquibase.url>
            <liquibase.driver>${database.driver}</liquibase.driver>
            <liquibase.username>${database.username}</liquibase.username>
            <liquibase.password>${database.password}</liquibase.password>
        </properties>
    </profile>
</profiles>

2. I tried using the Properties Maven plugin:

<plugin>
      <groupId>org.codehaus.mojo</groupId>
      <artifactId>properties-maven-plugin</artifactId>
      <version>1.0-alpha-2</version>
      <executions>
         <execution>
            <phase>initialize</phase>
            <goals>
               <goal>read-project-properties</goal>
            </goals>
            <configuration>
               <files>
                  <file>src/main/resources/local/db.properties</file>
               </files>
            </configuration>
         </execution>
      </executions>
   </plugin>

当我运行liquibase:更新maven目标时,我得到这个错误:

[ERROR] Failed to execute goal org.liquibase:liquibase-maven-plugin:3.1.0:update (default-cli) on project my-project: The driver has not been specified either as a parameter or in a properties file

似乎无法解析POM文件中引用的数据库属性 .

知道如何实现这一目标吗?

1 回答

  • 15

    我设法让这个工作 . 关键是将maven filter元素与资源元素结合使用,如Liquibase Documentation中所述 .

    在maven命令中包含资源目标也很重要:

    mvn resources:resources liquibase:update -Plocal
    

    这是我使用的文件层次结构:

    |-- pom.xml
    `-- src
        `-- main
           |-- resources
           |   `-- liquibase.properties
           |   |-- changelog
           |       `-- db-changelog-master.xml
           |       `-- db-changelog-1.0.xml
           |-- filters
               |-- local
               |   `-- db.properties
               |-- dev
               |   `-- db.properties
    

    db.properties文件如下所示:

    database.driver = oracle.jdbc.driver.OracleDriver
    database.url = jdbc:oracle:thin:@<host_name>:<port_number>/instance
    database.username = user
    database.password = password123
    

    liquibase.properties文件如下所示:

    changeLogFile: changelog/db.changelog-master.xml
    driver: ${database.driver}
    url: ${database.url}
    username: ${database.username}
    password: ${database.password}
    verbose: true
    

    POM文件如下所示:

    <build>
          <pluginManagement>
             <plugins>
                <plugin>
                   <groupId>org.liquibase</groupId>
                   <artifactId>liquibase-maven-plugin</artifactId>
                   <version>3.1.0</version>
                   <configuration>
                      <propertyFile>target/classes/liquibase.properties</propertyFile>
                   </configuration>
                </plugin>
             </plugins>
          </pluginManagement>
       </build>
    
    
    <profiles>
        <profile>
            <id>local</id>
            <activation>
                <activeByDefault>true</activeByDefault>
            </activation>
            <build>
                <filters>
                    <filter>src/main/filters/local/db.properties</filter>
                </filters>
                <resources>
                    <resource>
                        <directory>src/main/resources</directory>
                        <filtering>true</filtering>
                    </resource>
                </resources>
            </build>
        </profile>
        <profile>
            <id>dev</id>
            <build>
                <filters>
                    <filter>src/main/filters/dev/db.properties</filter>
                </filters>
                <resources>
                    <resource>
                        <directory>src/main/resources</directory>
                        <filtering>true</filtering>
                    </resource>
                </resources>
            </build>
        </profile>
    </profiles>
    

相关问题