优秀数据库模式迁移工具的发展历程

译文
数据库
从CLI到GUI,再到GitOps和数据库即代码(Database-as-Code),数据库模式迁移经历了漫长的过程。而人们需要了解数据库模式迁移工具的发展。

译者 | 李睿

审校 | 重楼

数据库模式迁移可能是应用程序开发中风险最大的领域——因为这是一个困难的、有风险的和痛苦的过程。数据库模式迁移工具的存在是为了减轻这种痛苦,并且已经取得了长足的进步:从基本的CLI工具到GUI工具,从简单的SQL GUI客户端到一体化协作数据库平台。

命令行客户端(CLI) - MySQL/PSQL

MySQL和PSQL分别是MySQL和PostgreSQL的本地CLI可以从命令行直接向MySQL或PostgreSQL服务器发送命令或查询。

尽管CLI界面很简单,但有时它会让初学者望而生畏。然而,根据Timescale公司的2022年PostgreSQL状态调查结果,PSQL是最受欢迎的与PostgreSQL交互的工具,超过了pgAdmin和DBeaver等GUI工具。

GUI

1.PHPMyAdminPGAdmin

PHPMyAdminPGAdmin是经典的SQL客户端。PHPMyAdmin已经是一个管理MySQL和MySQL兼容数据库(例如MariaDB)的工具,而PGAdmin是PostgreSQL的对应工具,现在已经发展到PGAdmin 4。与CLI工具相比,PHPMyAdminPGAdmin提供了一个用于运行和执行SQL查询的用户界面(UI),使它们更加友好。

2.DBeaver

DBeaver的最初版本发布于2010年,这款开源SQL客户端支持各种数据库(SQL、NoSQL和云数据库),并通过整合OpenAI公司的GPT功能跟上人工智能领域的最新趋势,允许将自然语言转换为SQL。

3.Navicat

Navicat于2001年首次发布。它当时只支持MySQL,但后来增加了更多的数据库。虽然Navicat的UI看起来有点过时,但它具有完整的功能,并且在操作数据库时提供了流畅的整体体验。

基于GUI的SQL客户端是对基于CLI的SQL客户端的良好补充。从根本上讲,它们的工作方式是一样的。用户可以快速方便连接到数据库并执行一些SQL。另一方面,在数据库更改管理和数据安全方面缺乏控制。本文将以Navicat为例进行详细介绍。

Gitops /数据库即代码

为了更好地管理和控制数据库模式更改,一些工具在数据库更改中引入了代码更改过程,称为数据库即代码(Database-as-Code)

1.Liquibase

Liquibase创建于2006年,是一个用于跟踪、管理和应用数据库更改的开源库。一个有趣的事实是:Liquibase于2012年被一家名为Datical的公司收购,并更名为Datica,但随后于2020年更名为Liquibase(这是明智之举,见过有人在论坛上提到过Datica吗?)。

Liquibase的主要产品是基于Java的CLI,它允许开发团队通过CLI将数据库模式迁移集成到他们的CI/CD工作流中。

2.Flyway

Flyway与Liquibase在很多方面有相似之处:它们都是成立时间较长的数据库,拥有客户群,而且都是开源项目。它的核心产品是CLI和Java库。

Flyway背后的商业实体是Redgate(于2019年被收购)。它有3个版本:社区、团队和企业。可以看出,他们在开源和商业产品之间划出了一条清晰的界限:Flyway的网站总体上感觉更随意,而Redgate的方式更专业。

Liquibase和Flyway并驾齐驱。两者的主要区别在于各自的定位:Liquibase更面向企业,而Flyway更面向开发者。

3.Sqitch

Sqitch是一个纯开源项目,自从2012年以来一直没有商业产品上市。它是纯粹的CLI,没有UI。

与基于Java的Liquibase和Flyway不同,Sqitch是使用Perl开发的。此外,Sqitch在如何管理数据库模式更改方面有自己的理念:Liquibase和Flyway都使用文件命名约定来安排模式迁移(约定高于配置)。

而Sqitch采用了一种显式的方法,允许用户在Sqitch计划中指定顺序。

4.Atlas

Atlas是一个由Ariga构建的开源工具,并推广了“数据库模式即代码”这一术语。

可以看出,他们从HashiCorp那里获得了很多灵感,并在首次出现在Hacker News上时将自己称为“数据库迁移的Terraform”。他们还发明了基于HCL (HashiCorp配置语言)的Atlas HCL。

Atlas使用现代编程语言Go(与使用Java的Liquibase/Fireway不同),并以CLI为中心(类似于Liquibase.Fireay/Sqitch),但它也有一个轻量级的UI。Atlas Cloud是一个开源版本的商业产品。

一体化:GUI + Gitops / Database-As-Code + Collaboration

1.Prisma

像Prisma这样的ORM针对的是代码如何与数据交互的领域。虽然这更多的是一个后端主题,但Prisma是一个具有前端根的ORM。前端工程师可能不是最精通SQL的。为了降低管理数据库模式的障碍,Prisma发明了它的DSL来定义数据模型。

DSL是基于状态的(声明性的),它描述了数据库模式的最终状态,而不是增量变化,这与Liquibase/Flyway/Sqitch不同。通过这种方式,Prisma可以在整个应用程序开发周期中提供更全面的数据库管理视图。

Prisma ORM是开源的,可以免费使用,他们的数据平台提供了一个基于云的协作平台,具有一些高级功能(很明显,他们的目标不仅仅是一个ORM和模式迁移工具)。

2.Bytebase

Bytebase是一个开源数据库DevOps工具,涵盖了数据库管理场景,从变更、查询、安全性到基于Web的可视化协作工作区的治理。

Bytebase提供了一个基于Web的UI,开发人员和DBA可以通过同一个界面协作处理数据库更改。

3.数据库即代码(Database-As-Code

为了更好地适应开发人员的工作习惯,Bytebase已经将功能集成到代码库中,例如itLab和GitHub。通过启用GitOps工作流,开发人员可以将数据库更改文件提交到熟悉的代码存储库,一旦审查完成并提交到repo, Bytebase将自动触发部署。无需在多个工具之间切换。

4.团队协作与管理

用户可以为两个级别的成员定义不同的角色:工作区和项目。可以为团队成员分配不同的角色,以便他们对不同的项目具有不同的权限;或者为每个项目配置审批工作流,例如指定负责此特定项目的特定DBA或QA。

Prisma和Bytebase的区别在于目标受众。Prisma主要针对前端/全栈开发人员,而Bytebase更专注于后端和DBA。这两款产品都提供协作功能,Prisma专注于单个项目中开发人员之间的协作,而Bytebase针对整个工程组织,即开发人员和DBA/平台工程/运营团队。

结语

如果用户以个人身份操作数据库,那么传统的CLI或GUI SQL客户端(如Navicat)就足够了。如果更喜欢与代码库集成,有像Liquebase和Flyway这样的解决方案。然而,对于类似Jira或GitLab的GUI和项目协作功能,可以选择Prisma和Bytebase。Bytebase是唯一一个提供组织范围管理功能的工具,除了使数据库更改更高效和更安全之外,还可以确保数据安全和治理。

原文标题:Evolution of Top Database Schema Change Tools,作者:Mila Wu

责任编辑:华轩 来源: 51CTO
相关推荐

2010-06-07 10:00:45

MySQL数据库

2010-03-31 13:47:22

Oralce数据库

2020-06-08 10:41:13

云计算数据工具

2020-02-27 09:00:00

数据库设计工具

2018-08-10 07:50:45

数据库数据库设计实践步骤

2021-11-15 08:24:17

数据库database同步工具

2011-05-11 10:26:36

MySQL数据库无缝迁移

2021-04-09 08:21:25

数据库索引数据

2022-07-27 08:12:44

SchemaHero云原生

2021-07-07 10:12:08

数据库工具技术

2011-09-23 09:09:38

数据库迁移

2020-08-13 07:42:15

数据库Flyway代码

2011-11-10 14:42:11

2014-12-09 14:03:51

甲骨文Oracle数据库

2022-02-10 10:51:35

数据库

2022-12-15 15:34:50

数据中心云迁移

2020-06-04 08:11:56

数据库开发SQL Server数据库

2012-06-11 18:07:03

2017-05-27 21:07:24

NFV网络功能虚拟化数据中心

2021-05-17 08:00:00

数据库工具Flyway
点赞
收藏

51CTO技术栈公众号