百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

从Solr到ES再到黑鸟,GitHub正式启动基于Rust新代码搜索引擎

yuyutoo 2025-01-02 20:10 3 浏览 0 评论

昨天GitHub官方发布消息,宣布其使用Rust语言重写的代码搜索引擎黑鸟系统Blackbird正式启用。关于黑鸟系统的历史和技术,今天虫虫就给大家普及一下。

概述

黑鸟系统的目标是实现开发人员快速搜索、导航和理解其代码,将关键信息置于上下文中,并最终提高他们的工作效率。 为实现这一目标,需要实现以下功能:

首先,一个完全重新设计的搜索界面,带有建议、补全以及对结果进行切片和切块的能力。

其次,需要完全从头开始构建了一个新的代码搜索引擎。新的引擎需要非常快(大约是旧代码搜索速度的两倍),功能更强大(支持子字符串查询、正则表达式和符号搜索),并且理解代码,将最相关的结果放在排名最前面。

最后,要完全重新设计GitHub的代码视图,将搜索、浏览和代码导航紧密集成。

Github代码搜索历史和问题

GitHub成立于2008年,最初使用Apache Solr来处理其代码搜索。

Solr被并入Lucene之后。 2013年Github团队使用Elasticsearch对其搜索进行了改造,基于Elasticsearch创建了一个新的搜索服务。

随后,基于Elasticsearch搜索服务屡次出现服务终端故障。

在探索了基于通用文本搜索产品来支持代码搜索,GitHub发现基于现有产品搭建的系统用户体验差,索引速度慢,托管成本高。

2020年GitHub内部开始了一个新项目黑鸟系统,用来解决搜索服务不稳定的问题。

黑鸟架构

黑鸟系统架构图如下:

黑鸟系统是基于Rust语言,从零开始构建搜索引擎,专门用于代码搜索领域。

黑鸟系统所要实现的用户体验愿景:

能够提出代码问题并通过迭代搜索、浏览、导航和阅读代码获得答案。

GitHub团队通过实践意识到其代码搜索与一般文本搜索有根本的区别。

首先、代码已经被设计成可以被机器理解,所以其内部在结构上、功能上和功能上下文上必然存在联系性。

同时搜索代码也有独特的要求,需要搜索标点符号(例如,句号或左括号);不能从查询中删除停用词;另外,代码搜索还需要支持正则表达式。

最后,GitHub的巨大仓库规模是一个很大的挑战。其基于Elasticsearch的搜索系统,需要花费数月的时间来索引当时800万仓库的代码。

目前GitHub仓库数已经超过了2亿,而且还在持续增长中,这对搜索引擎来说是个巨大的挑战。

目前GitHub可搜索库有4500万公开库,代码总量为115TB,还有155亿的相关文档。

千万级代码的索引

黑鸟系统所要解决的第一个问题是如何在合理的时间内构建对这4500万代码库的代码和文档进行索引。由Git的天然特性,其内容可通过哈希寻址并且GitHub 上实际上有很多重复内容,所以可行的策略是:

按Git blob对象ID进行分片 ,git对象天然这提供了一种在分片之间均匀分布文档同时避免任何重复的好方法。由于特殊的存储库,不会有任何热服务器,可以根据需要轻松扩展分片的数量。

将索引建模为树并使用增量编码来减少爬行量并优化索引中的元数据。元数据就像文档出现的位置列表(路径、分支和存储库)和有关这些对象的信息(存储库名称、所有者、可见性等)。 对于流行内容,此数据可能非常大。

黑鸟还专门进行了设计将查询结果在提交级别的基础上保持一致。

当用户从存储库范围的查询中获取结果时,其他人可能正在对全局结果进行分页并查看不同于先前但仍然一致的索引状态。使用其他搜索引擎很难做到这一点。黑鸟提供这种级别的查询一致性作为其设计的核心部分。

查询的生命周期

在实现了对代码的索引后,系统跟踪查询就比较容易实现了。比如黑鸟系统查询是符Rail组织用于查找Ruby编程语言编写的代码的正则表达式,格式为:

/arguments?/ org:rails lang:Ruby

查询路径的高级架构图:

在网站和分片之间是黑鸟查询服务(BQS),它协调接受用户查询并将请求分散到搜索集群中的每个主机。黑鸟系统使用Redis来管理配额和缓存一些访问控制数据。

前端接受用户查询并将其传递给BQS,查询服务将查询解析为抽象语法树,然后重写它,将诸如语言之类的东西解析为其规范的Linguist 语言ID,并在额外的条款上标记权限和范围。这样,就可以看到重写如何确保将从公共存储库或有权访问的任何私有存储库中获得结果。

接着查询分成n个请求,并行请求到后端分片服务:

BQS得到分片的结果后,聚合所有分片的结果,按分数重新排序,过滤(双重检查权限),并返回前100列表。搜索前端仍然需要做语法高亮,term高亮、分页,然后将渲染到页面呈现给用户。

来自各个分片的p99响应时间大约为100ms,但由于聚合响应、检查权限和语法突出显示等原因,总响应时间会稍长一些。一个查询占用索引服务器上的单CPU内核100ms,GitHub 现有一台64核主机大约每秒可以执行640个查询。性能非常强硬,而且由于天然地分布式分片,所以可以很方便实现水平扩展,为同时用户查询和未来增长提供了充足的空间(多加分片服务器即可)。

总结

黑鸟代码搜索系统是一个全新的基于Rust的高性能分布式代码搜索系统。GitHub团队基于现有业务和问题的解决基础积极探索重新开发出适合自己独特业务、规模和需求的系统值得每一个软件系统架构师学习和借鉴。

当然对于广大的码农来说,以后在GitHub站搜代码更方便和快捷,GitHub也对其新系统提供了丰富的文档(docs.github /en/search-github)希望大家赶紧探索尝试,找出一些好用的技巧来给大家分享。

相关推荐

YAML配置文件简介及使用(yaml 配置)

简介YAML是"YAMLAin'taMarkupLanguage"(YAML不是一种标记语言)的缩写。相比JSON格式的方便。...

教你如何解决最常见的58种网络故障排除方法

1.故障现象:网络适配器(网卡)设置与计算机资源有冲突。分析、排除:通过调整网卡资源中的IRQ和I/O值来避开与计算机其它资源的冲突。有些情况还需要通过设置主板的跳线来调整与其它资源的冲突。2.故障现...

一分钟带你了解服务器网卡(服务器网卡怎么用)

今天小编和大家聊一下服务器的网卡。什么是网卡?简单说网卡就是计算机与局域网互连的设备。计算机主要通过网卡接入网络。网卡又称为网络适配器或网络接口卡NIC(NetworkinterfaceCard)...

linux文件之ssh配置文件的含义与作用

ssh远程登录命令是操作系统(包括linux和window系统)下常用的操作命令,可以帮助用户,远程登录服务器系统,查看,操作系统相关信息。linux系统对于ssh命令有专门保存其相关配置的目录和文件...

Cilium 官方文档翻译 - IPAM(二)Kubernetes Host模式

KubernetesHostScopeciliumIPAM的kuberneteshost-scope模式通过选项ipam:kubernetes开启,将集群IP地址分配委托给每个独立的节点,并...

域名劫持跳转,域名劫持跳转的解决办法只需5步

简单来说,域名劫持就是把原本准备访问某网站的用户,在不知不觉中,劫持到仿冒的网站上,例如用户准备访问某家知名品牌的网上商店,黑客就可以通过域名劫持的手段,把其带到假的网上商店,同时收集用户的ID信息和...

Linux基本命令(linux基本命令总结)

...

Linux 磁盘和文件系统管理(linux磁盘管理fdisk)

1检测并确认新硬盘...

windows host文件怎么恢复?局域网访问全靠这些!

windowshost文件怎么恢复?windowshost文件是常用网址域名及其相应IP地址建立一个关联文件,通过这个host文件配置域名和IP的映射关系,以提高域名解析的速度,方便局域网用户使用...

Nginx配置文件详解与优化建议(nginx 配置详解)

1、概述今天来详解一下Nginx的配置文件,以及给出一些配置建议,希望能对大家有所帮助。...

Mac电脑hosts文件锁定,如何修改hosts文件权限

有时候我们需要修改hosts文件,但是网上很多教程都行不通,使用sudo命令也不行。其实有一个很简单的方法。打开终端命令行,使用如下命令即可:sudochflags-hvnoschg/etc/...

windows电脑如何修改hosts文件?(windows 修改hosts文件)

先来简单说下电脑host的作用hosts文件的作用:hosts文件是一个用于储存计算机网络中各节点信息的计算机文件;作用是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”,当用户在浏览器中...

Vigilante恶意软件行为怪异:修改Hosts文件以阻止受害者访问盗版网站

Sophos刚刚报道了一款名叫Vigilante的恶意软件,但其行为却让许多受害者感到不解。与其它专注于偷密码、搞破坏、或勒索赎金的恶意软件不同,Vigilante会通过修改Hosts文件...

hosts文件无法修改几种现象和解决方法

第一种、hosts文件修改完不是直接保存而是弹出另存为窗口解决:1、右击hosts文件——属性——把“只读”前面勾去掉。第二种、打开hosts文件时提示“你没有权限打开该文件,请向文件的所有者或管理员...

hosts文件位置在哪里,教你hosts文件位置在哪里

Hosts是一个没有扩展名的系统文件,其基本作用就是将一些常用的网址域名与其对应的IP地址建立一个关联"数据库",当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的I...

取消回复欢迎 发表评论: