当前位置:   article > 正文

Flyway介绍和使用_flyway使用

flyway使用

一 使用背景

在我们日常产品发布的过程中,代码的版本控制可以使用git、svn工具实现。对于数据库每当发布时会出现手动执行sql脚本进行升级数据库,中间经常出现一些漏写、错写情况,对数据库的版本与代码的版本不匹配,导致上线后出现数据库不同步的问题。flyway就是对数据库版本进行控制的工具,可以对不同环境的sql进行迁移操作。

二 简单介绍

Flyway 是一款开源的数据库版本管理工具。它可以很方便的在命令行中使用,或者在Java应用程序中引入,用于管理我们的数据库版本。

在项目或产品中,很难一开始就把业务理清楚,把数据库表设计好,因此数据表也会在迭代周期不断迭代。在Java应用程序中使用Flyway,能快速有效地用于迭代数据库表结构,并保证部署到测试环境或生产环境时,数据表都是保持一致的。

三 工作原理

当 Flyway 连接数据库中的 schema 后,会先检查是否已存在 flyway_schema_history 表,如果没有则创建。该表用于跟踪数据库的状态,如数据迁移的版本,迁移成功状态等信息。

当 flyway_schema_history 存在后,Flyway 会扫描文件系统或应用中的 classpath 目录的数据迁移文件,然后根据它们的版本号进行按序迁移。

flyway_schema_history 表记录的内容如下:

由于 flyway_schema_history 表中记录了迁移的版本号,如果文件的版本号小于或等于标记为当前版本的版本号,则忽略它们不执行。

四 配置流程

1 引入依赖

  1. <dependency>
  2. <groupId>org.flywaydb</groupId>
  3. <artifactId>flyway-core</artifactId>
  4. <version>6.1.0</version>
  5. </dependency>
  6. 复制代码

2 application.yml中添加相关配置

  1. spring:
  2. # 数据库连接配置
  3. datasource:
  4. driver-class-name: com.mysql.cj.jdbc.Driver
  5. url: jdbc:mysql://localhost:3306/flyway-demo?characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai
  6. username: root
  7. password: root
  8. flyway:
  9. # 是否启用flyway
  10. enabled: true
  11. # 编码格式,默认UTF-8
  12. encoding: UTF-8
  13. # 迁移sql脚本文件存放路径,默认db/migration
  14. locations: classpath:db/migration
  15. # 迁移sql脚本文件名称的前缀,默认V
  16. sql-migration-prefix: V
  17. # 迁移sql脚本文件名称的分隔符,默认2个下划线__
  18. sql-migration-separator: __
  19. # 迁移sql脚本文件名称的后缀
  20. sql-migration-suffixes: .sql
  21. # 迁移时是否进行校验,默认true
  22. validate-on-migrate: true
  23. # 当迁移发现数据库非空且存在没有元数据的表时,自动执行基准迁移,新建schema_version表
  24. baseline-on-migrate: true
  25. 复制代码

3 创建脚本存放文件夹

根据上面配置文件中的脚本存放路径,我们需要在resource目录下建立文件夹 db/migration

4 添加sql脚本

  1. 命名规则主要有两种:
  2. 仅需要被执行一次的SQL命名以大写的"V"开头,V+版本号(版本号的数字间以”.“或”_“分隔开)+双下划线(用来分隔版本号和描述)+文件描述+后缀名。例如: V20201100__create_user.sql、V2.1.5__create_user_ddl.sql、V4.1_2__add_user_dml.sql 。
  3. 可重复运行的SQL,则以大写的“R”开头,后面再以两个下划线分割,其后跟文件名称,最后以.sql结尾。(不推荐使用)比如: R__truncate_user_dml.sql 。
  4.   其中,V开头的SQL执行优先级要比R开头的SQL优先级高。
  5. 复制代码

五 插件配置

1 配置插件

在上面的配置中,以上步骤中,每次想要migration都需要运行整个springboot项目,并且只能执行migrate一种命令,其实flyway还是有很多其它命令的。maven插件给了我们不需要启动项目就能执行flyway各种命令的机会。

在pom.xml中引入flyway的插件,同时配置好对应的数据库连接。

  1. <build>
  2. <plugins>
  3. <plugin>
  4. <groupId>org.flywaydb</groupId>
  5. <artifactId>flyway-maven-plugin</artifactId>
  6. <version>5.2.4</version>
  7. <configuration>
  8. <url>jdbc:mysql://localhost:3306/flyway-demo?characterEncoding=utf-8&amp;useSSL=false&amp;serverTimezone=Asia/Shanghai
  9. </url>
  10. <user>root</user>
  11. <password>root</password>
  12. <driver>com.mysql.cj.jdbc.Driver</driver>
  13. </configuration>
  14. </plugin>
  15. </plugins>
  16. </build>
  17. 复制代码

2 命令说明

(1)baseline

对已经存在数据库Schema结构的数据库一种解决方案。实现在非空数据库新建MetaData表,并把Migrations应用到该数据库;也可以在已有表结构的数据库中实现添加Metadata表。

(2)clean

清除掉对应数据库Schema中所有的对象,包括表结构,视图,存储过程等,clean操作在dev 和 test阶段很好用,但在生产环境务必禁用。

(3)info

用于打印所有的Migrations的详细和状态信息,也是通过MetaData和Migrations完成的,可以快速定位当前的数据库版本。

(4)repair

repair操作能够修复metaData表,该操作在metadata出现错误时很有用。

(5)undo

撤销操作,社区版不支持。

(6)validate

验证已经apply的Migrations是否有变更,默认开启的,原理是对比MetaData表与本地Migrations的checkNum值,如果值相同则验证通过,否则失败。

六 版本管理

1 代码版本与数据库版本一致性

此问题有点坑,因为当前代码版本是在提交本次代码或sql脚本后生成的,若想保持两者一致,在提交sql脚本前,先获取当前版本号,在此基础上进行叠加

2 预发行版本与正式版本

比如在正式环境已经发行了V1.0.0,此版本与V1.0.1间隔了若干个预发行版本

3 多人提交脚本

如何保证版本不重复

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/595612
推荐阅读
相关标签
  

闽ICP备14008679号