Redian新闻
>
开源产品测评之SQL上线能力

开源产品测评之SQL上线能力

公众号新闻

作者:farmmer

某中小型公司运维兼 DBA,擅长 MySQL、Oracle 运维管理,也负责部分运维开发工作

本文来源:爱可生开源社区投稿



背景

近期,我司准备引入一款 SQL 审核产品来供内部流程使用,解决目前 SQL 人工上线的流程管控问题,目标是对业内的开源产品进行调研,选型一款作为落地方案,后期如果内部有需求可能会进行二次开发。我们最终选取 SQLE[1]Yearning[2]Archery[3] 进行了初步的使用和调研,我们内部关注产品的一些点:

  1. 是否较为简单的部署和运维;
  2. 规则是否能满足我们公司 SQL 规范,如果不满足至少要能二次开发;
  3. 具备 SQL 上线流程,是否满足要求;
  4. 产品稳定性,后期是否能得到支持。

下面是调研的过程,如果恰巧你也在调研 SQL 审核产品,希望能给你提供一些经验参考。

1、运维部署

功能对比


SQLEYearningArchery
手工部署
Docker

体验对比

由于公司内网无法访问公网,因此没有使用 Docker 部署,基本采用手工部署的形式进行,SQLE 和 Yearing 部署基本都算顺畅,但是 Archery 需要安装依赖,最终是选择在自己电脑虚拟机上装的。

  • SQLE:手工部署是使用 RPM 包,不用安装操作系统依赖,一键安装和启停,使用 systemd 维护进程对运维较为友好,但是 RPM 会有操作系统限制(CentOS);进行建库操作和修改配置文件即可跑起来;
  • Yearning:手工部署使用 ZIP 包,解压后和 SQLE 类似,不用安装操作系统依赖;进行建库操作和修改配置文件,额外执行一下 Install 操作,即可跑起来;
  • Archery:手工部署需要安装 Python 和依赖,操作较为复杂,搞了大半天没有成功最终放弃,采用 docker compose 部署了。

体验排名

(SQLE = Yearning)> Archery

2、审核能力

功能对比


SQLEYearningArchery
审核规则数量多(140+)较多(40+)较多(60+)
规则是否开源✅(MySQL 审核集成的 goInception)
规则应用粒度数据源级别配置全局配置全局(无法界面配置)
多库支持✅(社区版非 MySQL 未支持更多规则,需二开)❌(仅支持 MySQL系)✅(非 MySQL 规则少)

体验对比

相比来说 SQLE 支持的规则最多,但是其他数据库类型例如 Oracle,PG,官方只提供了简单的实现,只有一条规则(等于没有)。目前我们公司都是 MySQL,倒是影响不大。

  • SQLE:MySQL 部分的规则基本都覆盖到了我们公司的需求,有极少数后期可能考虑二开吧;与其他两款产品的最大区别是 SQLE 的规则粒度在数据源上,每个数据源(业务)可以设计自己的规则集这点比较灵活。规则展示列表上有规则的背景说明,对于规则的选取有点帮助。
  • Yearning:规则集合偏 DDL 更多点,DML 类的较少,没有覆盖到我们内部的一些规范,比较尴尬的是,规则这边是闭源的,我们后续如果二开比较被动。
  • Archery:内置支持了较多数据源类型,通过查看 goInception 文档,MySQL 部分支持的规则较多,但是在 Archery 界面上审核规则无法查看,也不能配置需要开启哪些规则,目前看不太符合我们公司需求。

体验排名

SQLE > Archery > Yearning

3、SQL 工单上线

功能对比


SQLEYearningArchery
工单审批流程
可视化配置流程
自动上线
限制运维时间
定时上线✅(不支持修改定时时间)
线下执行
Online DDL
DML 事务执行
支持备份
消息通知

体验对比

目前对于 SQL 上线流程来说,三家基本功能都是具备的,都符合我们公司的需求。比较有差异的部分是,SQLE 支持 DML 事务执行,对工单内数据一致性会有帮助;Yearning 和 Archery 支持上线前备份。

  • SQLE:流程配置方式最简单,基本在项目界面下就能看到。
  • Yearning:流程配置方式也较简单,特点要求 DML 和 DDL 分开提交,如果你们公司有这方面的规范那么这个是个不错的功能;工单提交有个比较反人类的操作,大部分操作都是按钮的形式,但是 SQL 审核没有按钮,在右键菜单里,由于试用时不太清楚搞了很久,最终在社区群里询问才解决。还有个问题是定时上线时间无法改期。
  • Archery:流程配置比较麻烦,一度没有找到功能在哪里,配置过程反复在Archery UI 和 Django 管理界面横跳,没有统一的操作体验。

功能排名

(SQLE  = Yearning)> Archery

4、产品支持

功能对比


SQLEYearningArchery
迭代速度
开发者公司个人个人
问题支持
文档

体验对比

目前来看三款产品都是还在活跃有提交的项目,其中 SQLE 提交非常活跃,看 Release 信息基本每个月都会发布新版本。对于小公司来说其实区别没太大,基本目前使用上的问题各家文档上都能找到答案。

排名对比

SQLE  > Yearning > Archery

总结

目前我们公司正在试用 SQLE,已经接管了大概 5 套环境,还在进一步体验中。

本次只对几款开源 SQL 审核产品的 SQL 审核上线能力进行了试用,当然各家都还有很多有意思的功能,我暂时没有体验,大家可以根据自身情况进行选型。

参考资料

[1]

SQLE: https://github.com/actiontech/sqle

[2]

Yearning: https://github.com/cookieY/Yearning

[3]

Archery: https://github.com/hhyo/Archery


往期推荐



Rust内部大乱斗不休止

中文编程语言——青语言开源发布

国区JetBrains产品最新定价公布,比美区贵



这里有最新开源资讯、软件更新、技术干货等内容

点这里 ↓↓↓ 记得 关注✔ 标星⭐ 哦


微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
线上 MySQL 的自增 id 用尽怎么办?双林奇案录第三部之天禅寺:第二十节MySQL 处理大数据表的 3 种方案,写的太好了,建议收藏!!MySQL高级进阶:索引优化旧金山艺术宫(Palace of Fine Arts),艺术建筑又一个 SQL 神器,开源了!必囤好课|三周带你从0到1掌握Python, SQL, Excel等核心技能,课程免费无限次回放!Pulumi实战 | 一款架构即代码的开源产品SQL开源替代品,诞生了!当LLM遇到Database:阿里达摩院联合HKU推出Text-to-SQL新基准​从MySQL到OBOracle:如何处理自增列?双林奇案录第三部之天禅寺:第十九节高效方案:30万条数据插入 MySQL 仅需13秒在 MySQL 中处理时间 | Linux 中国陌上花开1014 叮~ 一枚能量Girl上线 ▏南开博士,热爱生活的工程师小姐姐~面试数据岗时,怎么把自己的SQL技能展现出来?长篇小说《如絮》第一百一十三章 旧金山-1956年 温柔地爱我大数据SQL数据倾斜与数据膨胀的优化与经验总结硬核观察 #1037 PostgreSQL 超过 MySQL 成为开发者首选数据库盘一盘G5新专业|UCL上新!《2023 大语言模型综合能力测评报告》出炉:以文心一言为代表的国内产品即将冲出重围FlinkSQL 数据权限之数据脱敏解决方案一条SQL如何被MySQL架构中的各个组件操作执行的?阿里一面:MySQL 单表数据最大不要超过多少行?为什么?MySQL主从复制原理剖析与应用实践威孚仕VFS Global成都芬兰签证申请中心将恢复运营!威孚仕VFS Global上海冰岛签证申请中心将全新启动!慢SQL是如何拖垮数据库的?奇怪的SQL问题+1MySQL 巨坑:永远不要在 MySQL 中使用 UTF-8!!云计算开源产业联盟:2023年中国企业开源治理全景观察报告16 年等待,再见 SQL Boy,这一次数据库交互形态彻底被颠覆了!克罗地亚杜布罗夫尼克(Dubrovnik),海边古城ClickHouse和PostgreSQL:“数据天堂”中的好搭档Java中如何解析、格式化、生成SQL语句?PHP程序员薪资竟然垫底、PG取代MySQL成为最流行数据库
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。