Flyway

Evolve your Database Schema easily and

reliably across all your instances

简单的、可靠的升级(发展)你的数据库模式,通过所有你的实例。

Why database migrations?    为什么要进行数据库的迁移

First,let's start from the beginning and assume we have a project called Shiny and its primary deliverable is a piece of sofeware called Shiny Soft that connects to a database called Shiny DB.B

首先,假设我们我们有一个叫做Shiny的项目,这个项目最初的交付物是一系列的叫做Shiny的软件。这个软件连接到一个叫做Shiny DB的数据库。

The simplest diagram to represent this could look something like this:

最简单的去呈现这个关系的示意图是:

We have our software and our database. Great. And this could very well be all you need.

我们有我们自己的软件和数据库。很好,并且运行良好。

But on most projects, this simple view of the world very quickly translate into this:

但是在大多数的项目上,这个简单的场景很快转变成这种方式:

                                                       We now not only have to deal with one copy of our environment,but with serveral.This presents a number of challenges.

 我们现在不仅必须要处理一个我们环境的副本,更多的时候是处理好几个。这个将会是一个很大的挑战。

We have been pretty good at solving them on the code side.

我们已经有了相当好的解决办法在我们的代码上。

   ·Version control is now universal with better tools everyday.    版本现在普遍的被很好的工具每天控制着。

   ·We have reproducible builds and continuous integration.       我们有再生的创建机制和连续的综合机制。       

   ·We hava well defined release and deployment processes.       我们有很好的定义发布和开发的过程、

    

   But what about the database?                                         但是我们的数据库该如何控制呢?

    

Well unfortunately we have not been doing so well there.Many projects still rely on mannually applied sql scripts.

不幸的是我们这方面做的并不是很好。很多项目依然依靠人工去执行脚本。

And sometimes not even that(a quick sql statement here or there to fix a problem).And soon many questions arise:

并且有时候问题还不止这些(如何从这或者哪快速的收集脚本清单也将是个问题)。马上一些问题将会产生:

· What state is the database in on this machine?                                        数据库在这台机器上是什么状态?

` Has this script already been applied or not ?                                           这个脚本到底执行了没有呢?

`Has the quick fix in production been applied in test afterwards?                在测试环境中有快速解决生产中问题的吗?

`How do you set up a new database instance?                                           如何建立一个新的数据库实例呢?

More often than not the answer to these questions is : We don't know.           更多的时候,我们不知道如何回答这些问题:我们不知道。

Database migrations are a great way to regain control of this mess.    数据库迁移是一个很好的方式去处理这些混乱的情况.

They allow you to :                                                                                   他们会让你:

`Recreate a database from scratch                                                            ·从错乱的情况下重新创建一个数据库

`Make it clear at all times what state a database is in                                  ·可以实时的清楚的目前数据库是个什么状态

`Migrate in a deterministic way from your current version of the database to a newer one       ·以一种确定性的方式迁移从当前版本的数据库更新

数据库版本管理工具Flyway(4.0.3)---介绍(译文)的更多相关文章

  1. 数据库版本管理工具Flyway(4.0.3)---工作机制(译文)

    How Flyway works The easiest scenario is when you point Flyway to an empty database. 最容易的方案是Flyway指向 ...

  2. [jOOQ中文]3. 数据库版本管理工具Flyway

    https://segmentfault.com/a/1190000010526452 在执行数据库迁移时,我们推荐使用jOOQ与Flyway - 数据库迁移轻松. 在本章中,我们将简单的来使用这两个 ...

  3. 数据库版本管理工具--Flyway的使用

    软件开发正常流程是:开发环境 ---> 测试环境  ----> 产环境 在开发过程中经常需要变更数据库: 表结构变更. 基础数据变更. 最直接的做法是:用客户端连上数据库直接修改. 依次修 ...

  4. 数据库版本管理工具Flyway——基础篇

    Flyway 默认规约 SQL 脚本文件默认位置是项目的源文件夹下的db/migration 目录. Java 代码默认位于db.migration 包. SQL 脚本文件及Java 代码类名必须遵循 ...

  5. 数据库版本管理工具flyway

    引入flyway_core  jar包 java 代码实现 public class FlywayMigration { @Resource private DataSource dataSource ...

  6. 【flyway】开源的数据库版本管理工具【migration】

    开源的数据库版本管理工具[migration] 记录

  7. 在SpringBoot中使用flyway进行数据库版本管理

    本文大纲 flyway是什么 能帮助我们解决什么问题 springboot环境下使用flyway flyway的工作原理 一.flyway是什么 Flyway是一个开源的数据库版本管理工具,并且极力主 ...

  8. Java敏捷数据库迁移框架——Flyway

    1.引言 想到要管理数据库的版本,是在实际产品中遇到问题后想到的一种解决方案,当时各个环境的数据库乱作一团,没有任何一个人(开发.测试.维护人员)能够讲清楚当前环境下的数据库是哪个版本,与哪个版本的应 ...

  9. 使用alembic进行数据库版本管理

    前言 随着项目业务需求的不断变更,数据库的表结构修改难以避免,此时就需要对数据库的修改加以记录和控制,便于项目的版本管理和随意的升级和降级. Alembic就可以很好的解决这个问题.Alembic是S ...

随机推荐

  1. REMOTE HOST IDENTIFICATION HAS CHANGED

    今天在使用scp命令上传文件到远端服务器时报如下错误,(ssh命令连接到远程服务器时也报同样的错误): @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ...

  2. javascript基础之javascript的存在形式和js代码块在页面中的存放位置

    1.存在形式 文件 如: <script src='js/jc.js'></script> 前页面 <script type='text/javascript'>a ...

  3. Eclipse下Maven插件配置

    要做一个基于C/S架构的汽车租赁系统,由于在实习期间接触过一些Java和SpringMVC,Spring,Hibernate的东西,所以决定使用这个框架组合来完成这个项目. 首先是Maven的配置,为 ...

  4. vs连接mysql

    1.打开vs2012在aspx中添加一个Grid view 控件,,. 2,选择新建数据源. 3,选择数据库. 4,选择新建连接. 5,更改成mysql连接. 6,这里的Server name 是你自 ...

  5. git some cookies

    *首先得配置和本地的操作实际上都很简单,忽略了:*git 添加远程仓库 git remote add 仓库名 url:*先pull下来,语法 git pull 远程仓库名 远程分支名[:当地分支名], ...

  6. Android开发环境搭建简介

    Android的开发工具,可以使用Eclipse,Idea,Android Studio,其中Eclipse是开源中国大部分使用的IDE,Idea是号称最好用的开发工具,有很多用处,Android S ...

  7. linux 第二天

    文件权限和用户组 groupadd 组名 groupadd policeman 查看组 vi /etc/group cat /etc/group 创建用户,并同时指定将该用户分配到哪个组 userad ...

  8. Oracle数据库名、实例名、数据库域名、全局数据库名、服务名之间的区别

    数据库名.实例名.数据库域名.全局数据库名.服务名 这是几个令很多初学者容易混淆的概念.相信很多初学者都与我一样被标题上这些个概念搞得一头雾水.我们现在就来把它们弄个明白. 一.数据库名 什么是数据库 ...

  9. [转]C++智能指针的创建

    zero 坐在餐桌前,机械的重复“夹菜 -> 咀嚼 -> 吞咽”的动作序列,脸上用无形的大字写着:我心不在焉.在他的对面坐着 Solmyr ,慢条斯理的吃着他那份午餐,维持着他一贯很有修养 ...

  10. C++ 性能剖析 (二):值语义 (value semantics)

    Value Semantics (值语义) 是C++的一个有趣的话题. 什么是值语义? 简单的说,所有的原始变量(primitive variables)都具有value semantics. 也可以 ...