博客
关于我
用 SQL 查询 Git 仓库
阅读量:663 次
发布时间:2019-03-15

本文共 1001 字,大约阅读时间需要 3 分钟。

Git 已经成为了代码版本控制的事实标准,但尽管它广泛应用,对代码仓库的深入分析工作的难度却并没有因此降低。另一边,SQL 在大型代码库查询方面已经成为考验的语言,许多项目如 Spark 和 BigQuery 正是基于此选择它作为分析工具。或许源代码本身并不具备这种双重能力,因此我们开发出了 GitBase。

GitBase:代码即数据的见解

GitBase 是一个开源项目,它将代码作为数据处理的解决方案。它能够通过 SQL 对 Git 仓库进行大规模分析。作为一家开源公司,我们深知开源之力,GitBase 的发展完全依赖于其他开源项目的支持。这使得它具备了强大的技术基础。

这款工具为用户提供了一个可视化操作环境,使得复杂的数据分析变得直观易用。沟通方式更地,我们利用 Vitess 解析 SQL 请求。Vitess 是 YouTube 开发的横向扩展的 MySQL 集群系统,它为 GitBase 提供了坚实的基础。

在数据检索方面,我们选择了 go-git 这一纯 Go 语言开发的 Git 实现。它不仅高效,还具备极高的可扩展性。我们可以通过将本地存储的 Git 仓库转换为文件格式,或者使用 Git clone 的方式获取完整的代码库。

言外之意,我们重视代码历史分析能力,因此集成了 enry 这个语言检测项目以及 babelfish 的代码解析服务。不仅限于简单的语法检测,它还能够解析文件,生成通用抽象语法树。这些功能使得 GitBase 能够满足如“查找最常修改的函数名称”等复杂需求。

性能优化关键

在处理超大规模数据时,性能至关重要。以 GitHub 的 3 TB 高达源代码为例,我们确实面临着巨大的工作量,因此每个细节都需要优化。在构建 GitBase 时,我们引入了 Rubex 和 Pilosa。

Rubex 是 Go 标准库中替代正则表达式的高性能解决方案。其背景是 C代码优化,能够显著提升处理速度。Pilosa 则是我们为解决大型数据集查询速度问题而选择的分布式位图索引项目。结合两者,GitBase 实现了对大规模查询的支持。

开发总结

此文本始终站在开源项目的肩膀上,它凝聚了无数开发者的智慧。如你想尝试 GitBase ,从 sourced.tech/engine 下载即可。通过单一命令即可运行,简便又高效。若你对其功能感兴趣,可关注我的相关演讲内容。

转载地址:http://auxmz.baihongyu.com/

你可能感兴趣的文章
PFX(Parallel Framework) and Traditional Multithreading
查看>>
PGOS:今天动手给电脑装青苹果Win7 X64位系统
查看>>
pgpool-II3.1 的内存泄漏(一)
查看>>
PgSQL · 特性分析 · PG主备流复制机制
查看>>
PGSQL主键序列
查看>>
PGSQL安装PostGIS扩展模块
查看>>
pg数据库中两个字段相除
查看>>
PhalApi:[1.23] 请求和响应:GET和POST两者皆可得及超越JSON格式返回
查看>>
Phalcon环境搭建与项目开发
查看>>
Phantom.js维护者退出,项目的未来成疑
查看>>
Pharmaceutical的同学们都看过来,关于补码运算的复习相关内容
查看>>
Phaser性能测试加强版
查看>>
phoenix 开发API系列(一)创建简单的http api
查看>>
Phoenix 查看表信息及修改元数据
查看>>
phoenixframework集成了所有自动化测试的思想的平台。mark一下。
查看>>
phoenix_执行sql报错_Error: ERROR 504 (42703): Undefined column. columnName=(state=4270_大数据工作笔记0181
查看>>
phoenix启动失败_The history file `/root/.sqlline/history` may be an older history---记录024_大数据工作笔记0184
查看>>
Phoenix基础命令_视图映射和表映射_数字存储问题---大数据之Hbase工作笔记0036
查看>>
phoenix无法连接hbase shell创建表失败_报错_PleaseHoldException: Master is initializing---记录020_大数据工作笔记0180
查看>>
Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
查看>>