Flyway数据库版本控制

前言:最近工作上遇到个问题,项目开发过程中,开发代码可以通过svn来版本控制,但数据库又该如何来管理呢?多个人接触数据库,当对表、字段或数据修改后,又怎么来同步呢?经过苦寻,发现了个叫flyway的开源项目:http://flywaydb.org/,java编写,官方的介绍就是我的初衷,岂能不心动?

 

官网是英文的,查了下居然没有中文文档,难道没有中国人用?

 

慢慢看了下官方文档,试着做了下,一次成功!(离开电脑,蹦达几下,继续坐回电脑)

 

自己写个小教程吧

 

1、将flyway-core-2.3.jar放到项目lib中,下载地址:http://flywaydb.org/getstarted/download.html

 

2、在src目录下建立保存sql版本文件的路径:src/db/migration,flyway默认查找路径,可以改,但没必要。


 
  

 

3、在sql版本文件路径中增加sql文件,命名规则,如:V1__2014_4_13.sql ,V开头+版本号+双下划线+描述,描述中可以有下划线,后缀为sql。别问能不能修改这个规则,否则,我咬你。

 

4、增加flyway的java类,有命令行工具,但还是java类用起来方便,如下:

package com.cms.flyway;

import java.io.IOException;
import java.util.Properties;

import com.googlecode.flyway.core.Flyway;

public class FlywayApp {
    
    // 读取数据库配置参数
    private static Properties config = new Properties();
    static {
        try {
            config.load(Thread.currentThread().getContextClassLoader().getResourceAsStream("activerecord.properties"));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    
    // 执行数据库版本升级
    public static void migration() {
        // Create the Flyway instance
        Flyway flyway = new Flyway();
        
        // Point it to the database
        flyway.setDataSource(config.getProperty("com.et.ar.ActiveRecordBase.url"), config.getProperty("com.et.ar.ActiveRecordBase.username"), config.getProperty("com.et.ar.ActiveRecordBase.password"));
        flyway.setInitOnMigrate(true);
        
        // Start the migration
        flyway.migrate();
    }
}
<!-- 数据库自动更新 -->
    <bean id="baselineVersion" class="org.flywaydb.core.api.MigrationVersion">
        <constructor-arg value="2.5"/>
    </bean>
    <bean id="flyway" class="org.flywaydb.core.Flyway" init-method="migrate">
        <property name="dataSource" ref="dataSource"/>
        <property name="baselineOnMigrate" value="true" />
        <property name="baselineVersion" ref="baselineVersion" />
        <property name="outOfOrder" value="true" />
    </bean>

    <!--整合hibernate-->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean" depends-on="flyway" >
         <!--方案一:Druid数据源配置-->
         <property name="dataSource" ref="dataSource"></property> 
         <!--方案二:数据源配置--> 
        <!--<property name="dataSource" ref="myP6DataSource"></property>-->
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=${jdbc.hibernate.dialect}
                hibernate.show_sql=${jdbc.hibernate.show_sql}
                hibernate.format_sql=${jdbc.hibernate.format_sql}
                hibernate.current_session_context_class=org.springframework.orm.hibernate4.SpringSessionContext
                hibernate.id.new_generator_mappings=true
              
                <!-- 配置hibernate的二级缓存 -->
                hibernate.cache.use_query_cache=true
                hibernate.cache.use_second_level_cache=true
                hibernate.cache.region.factory_class=org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory
            </value>
        </property>
        <property name="packagesToScan">
            <value>com.founder.mrp.domain</value>
        </property>
    </bean>

从上面的bean 定义中我们可以看到,我们为flywayMigration 这个bean 实例注入了一个数据源,Flyway 的所有操作将针对这个数据源进行;同时我们通过init-method 属性指定了Spring 在实例化该bean 以后,主动执行该bean 的migrate 方法,而该方法内会执行Flyway 更新数据库的操作。至此,我们达到了在应用启动时,Spring 实例化上下文的时候,在Spring 实例化flywayMigration 这个bean 的时候,自动执行Flyway 更新数据库的操作。

但是,我们还没有达到目的,万一Flyway 还在更新数据库,没有完成更新操作之前,应用程序的其他逻辑已经开始使用数据库进行其他操作了,会导致应用程序产生很多bug ,甚至根本运行不起来。

要解决这个问题,我们可以利用Spring 的bean 依赖原理,让关键的数据库操作bean 依赖于flywayMigration 这个bean ,达到在flywayMigration 没有实例化完成(数据库更新操作完成)之前,不能进行任何其他数据库相关操作。

利用Spring 的bean 依赖让flywayMigration 优先处理数据库更新操作:

<!-- 将连接池注入到 JdbcTemplate对象 -->

<beanid="jdbcTemplate"class="org.springframework.jdbc.core.JdbcTemplate"depends-on="flywayMigration1">

    <property name="dataSource"ref="dataSource"></property>

</bean>

至此,运行就可以了。

  

5、在服务器启动的时候或者定时器 执行该类的migration()方法即可。

 

6、第一次执行会生成一个专门存放数据库schema_version的表



 

7、以后数据库有了新的改动,导出新版本sql文件(如:mysqldump -u -p databasename>/xx.sql)改为新版本命名文件放到db.migration路径下,flyway会自动帮你更新数据库版本的。

 

over!

转自:https://www.cnblogs.com/qq739178184/p/5119111.html

posted @ 2020-05-12 10:34  霞光里  阅读(1692)  评论(0编辑  收藏  举报