Archery:开源、一站式的数据库 SQL 审核与运维平台

01 引言

很多公司在项目发布的时候,都可能伴随着SQL语句的执行,如处理历史数据、修改表字段等。如果SQL的质量不好,很容易导致锁表、同步延迟等异常问题。于是纷纷加入了SQL审核的机制。

SQL的审核原本是由DBA负责的,但是我们没有DBA,只能由有经验的开发人员和运维团队负责。运维团队就使用Archery搭建了SQL审核平台,用于SQL的审核和管理,但是最后由于种种原因没有使用起来。

个人觉得里面的很多功能还是挺好用的,就分享给大家。

02 Archery 简介

Archery由国内优秀的开源团队开发和维护,它并非某个单一功能的工具,而是一个统一的数据库管理门户。其核心设计理念是通过一个 Web 平台,将分散的数据库管理操作集中化、流程化和自动化。

主要的功能包括了强大的SQL审核与执行、卓越的SQL查询与优化、多数据库类型的支持以及全面的运维管理功能,如实例管理、账号权限、性能监控等。

功能清单一览表:

GitHub地址:github.com/hhyo/archer...

03 环境搭建

本文以Docker的方式部署。

部署地址:github.com/hhyo/archer...

3.1 启动

安装说明上需要我们自行下载Releases,然后步骤执行脚本即可。但是小编部署下来,发现调了几个小步骤。

我们可以执行通过名命令直接下载:

sh 复制代码
# 克隆仓库
git clone https://github.com/hhyo/Archery.git

# 进入
cd Archery/src/docker-compose

如图:

然后就可按照官方文档一步步进行了。过程中可能需要设置用户名和密码,我这里设置的是:superuser/superuser

3.2 访问

访问地址:http://IP:9123

需要使用部署时的用户名和密码即可登录。

3.3 初体验

在这个平台有很多的功能:

  • SQL审核
  • SQL查询
  • SQL优化
  • 实例管理
  • 工具插件
  • 系统管理
  • 系统审计
  • OpenAPI

04 主要功能

里面功能不较多,这里介绍一下小编比较喜欢的几个模块。

4.1 实例管理

实例管理就是连接的数据库。我们需要进入后台管理,增加实例。

进去之后,就可新增实例了。

4.2 SQL审核

SQL审核时工单的形式提交,类似一个工作流。

在这里可以提交新的要执行的SQL

发起工单

发起工单需要在管理后台。完成之后,就可以在审核平台看见了。

4.3 SQL查询

这里就好比一个客户端,

这里可以像navicat一样编写SQL且有提示功能。还有表结构,查询结果以及执行的历史记录等。

数据字典更是可以列出表信息以及导出:

4.4 SQL 优化

这里可以分析SQL语句并给出建议,这无疑是SQL初学者的福音

还可以直接管理慢SQL

05 小结

Archery里面还有很多功能,大家可以自行探索。很多人可能觉得不好用,那是因为没有解决你的痛点。而作为一个免费开源的工具,已经是很良心了,况且功能还很丰富。大家可以根据自己的需求,关注适合自己的模块,可能会带来不一样的收获。

相关推荐
AI小智2 小时前
为了帮我搞定旅行清单:我的小白老婆报名了30万奖金的黑客松!
后端
双向332 小时前
RTX 4090助力深度学习:从PyTorch到生产环境的完整实践指南
后端
shengjk12 小时前
Java vs Python Web 服务器深度对比:从传统到现代的演进之路
后端
绝无仅有2 小时前
某辅导教育大厂真实面试过程与经验总结
后端·面试·架构
绝无仅有2 小时前
Java后端技术面试:银行业技术架构相关问题解答
后端·面试·github
这里有鱼汤2 小时前
【花姐小课堂】新手也能秒懂!用「风险平价」打造扛造的投资组合
后端·python
CodeSheep2 小时前
当了leader才发现,大厂最想裁掉的,不是上班总迟到的,也不是下班搞失联的,而是经常把这3句话挂在嘴边的
前端·后端·程序员
shark_chili3 小时前
Git Worktree:优雅解决多分支开发痛点的终极利器
后端
程序员爱钓鱼3 小时前
Go语言实战案例-项目实战篇:新闻聚合工具
后端·google·go