【AICon】探索八个行业创新案例,教你在教育、金融、医疗、法律等领域实践大模型技术! >>> 了解详情
写点什么

开源 Querybook:Pinterest 的大数据协作枢纽

  • 2021-04-29
  • 本文字数:2458 字

    阅读完需:约 8 分钟

开源Querybook:Pinterest的大数据协作枢纽

针对日益远程化世界的高效大数据解决方案

 

Pinterest 拥有超过 3000 亿的 Pins,而这一数字背后是一个不断增长的独特数据集,通过数据映射无数人的兴趣、想法和意图。作为一家数据驱动的公司,Pinterest 使用数据洞察和分析技术来做出产品决策和评估,为超过 4.5 亿的月活用户改善 Pinner 的体验。为了持续做出这些改进,尤其是在今天这个日益远程化的世界中,与过去相比,团队更需要进行查询、创建分析并彼此高效协作。今天我们正在使用 Querybook,这是我们实现更高效、更协作的大数据访问的解决方案,我们还在向社区开源这一项目。

 

无论在 Pinterest 上发起任何分析,一个常见起点是可以在 SparkSQL、Hive、Presto 集群或任何 Sqlalchemy 兼容引擎上执行的即席查询。我们构建了 Querybook 来为此类分析提供一个响应快速且简单的 WebUI,以便数据科学家、产品经理和工程师发现正确的数据、构建他们的查询并分享他们的成果。在本文中,我们将讨论构建 Querybook 的动机,其特性、架构以及我们将项目开源的工作。

旅程

创建 Querybook 的提议始于 2017 年,它一开始是一个内部项目。在那时,我们使用的是一个供应商提供的 Web 应用程序作为查询 UI。用户经常抱怨该工具的 UI、速度和稳定性、缺乏可视化、难以分享等缺陷。不久之后,我们意识到人们非常需要一个更好的查询界面。

 

在确定技术细节时,我们开始采访数据科学家和工程师,咨询他们的工作流程的细节。不久,我们意识到大多数人是在官方工具之外组织他们的查询,很多人使用 Evernote 之类的应用。虽然 Jupyter 有自己的笔记本用户体验,但它需要使用 Python/R,而且它缺乏表元数据集成的问题劝退了很多用户。基于这一发现,我们的团队决定 Querybook 的查询界面将是一个文档,用户可以在该文档中通过搭配元数据和一个简单的笔记应用,一站式完成查询构建和编写分析任务。

 

Querybook 于 2018 年 3 月在内部发布,成为了 Pinterest 上查询大数据的官方解决方案。如今,Querybook 平均有 500DAU 和 7k 的每日查询运行。它的内部用户评级为 8.1/10,是 Pinterest 内部评级最高的工具之一。

特性亮点

图 1 Querybook 的 Doc UI

 

用户首次访问时,他们会很快注意到其独特的 DataDoc 界面。这是用户进行查询和分析的主要位置。每个 DataDoc 均由一系列单元格组成,这些单元格可以是以下三种类型之一:文本、查询或图表。

 

  • 文本单元格带有内置的富文本支持,以供用户记下他们的想法或见解。

  • 查询单元格用于组成和执行查询。

  • 图表单元格用于根据执行结果创建可视化效果。类似 Google Docs,授予用户访问 DataDoc 的权限后,他们可以共同实时协作。

 

通过直观的图表 UI,用户可以轻松地将 DataDoc 变成一个展示内容的仪表板。你可以选择多种可视化选项,例如时间序列、饼图、散点图等。然后你可以将可视化连接到 DataDoc 任意查询的结果上,并按需对它们做排序和聚合预处理。要自动更新这些图表,你可以使用计划选项并选择所需的时间安排。计划程序可以通知用户成功或失败的结果。结合 Jinja 提供的模板选项,创建实时更新 DataDoc 的速度非常快。

 

计划任务和可视化特性并不是要取代 Airflow 或 Superset 之类的工具,而是为用户提供了一种简单快速的方法来对其查询进行实验和迭代。Pinterest 工程师通常将 Querybook 用作撰写查询的第一步,之后再创建生产级工作流和仪表板。

 

最后一点也很重要,Querybook 带有一套自动查询分析系统。它可以对每个执行的查询进行分析,以提取元数据(例如引用的表和查询运行器)。Querybook 使用这些信息自动更新其数据模式和搜索排名,并显示表的常用用户和查询示例。查询越多,表的文档化程度就越高。

架构工程

图 2 Querybook 的架构概述

 

为了了解 Querybook 的工作机制,我们来过一遍编写和执行查询的过程。

 

  1. 第一步是创建一个 DataDoc 并将查询写入一个单元格中。当用户键入内容时,用户的查询将通过 Socket.IO 流式传输到服务器。

  2. 然后,服务器将这些增量推送给所有通过 Redis 读取该 DataDoc 的用户。同时,服务器会将更新的 DataDoc 保存在数据库中,并为 worker 创建一个异步作业以更新 ElasticSearch 中的 DataDoc 内容,待以后搜索。

  3. 编写完查询后,用户可以单击运行按钮来执行查询,然后服务器将在数据库中创建一条记录,并将一个查询作业插入到 Redis 任务队列中。上述 worker 接受任务并将查询发送到查询引擎(Presto、Hive、SparkSQL 或任何与 Sqlalchemy 兼容的引擎)。在查询运行时,worker 通过 Socket.IO 将实时更新推送到 UI。

  4. 执行完成后,worker 加载查询结果并将其分批上传到一个可配置的存储服务(例如 S3)中。最后,浏览器将收到查询完成通知,并向服务器发出一个请求以加载查询结果,显示给用户。

 

简短起见,本节仅关注 Querybook 的一个用户流,但已经涵盖了其所使用的所有基础架构。Querybook 允许用户自定义其中的一些部分。例如,你可以选择将执行结果上传到 S3、Google Cloud Storage 或本地文件。另外,MySQL 也可以与任何与 Sqlalchemy 兼容的数据库(例如 Postgres)互换。

开源之路

在注意到 Querybook 在内部取得的成功之后,我们决定将其开源。我们遇到的一个挑战是如何在保留一些特定于 Pinterest 的集成的同时让它适合通用场景。为此,我们决定通过一套插件系统来做一个两层的组织,并添加一个 Admin UI(管理界面)。

 

借助 Admin UI,其他公司可以通过单个友好的界面来配置 Querybook 的查询引擎、表元数据提取和访问权限。以前,这些配置是在配置文件中完成的,需要更改代码并部署才能生效。有了这个新的 UI,管理员无需更改代码或配置文件即可进行实时 Querybook 更改。

图 3 Admin UI

 

插件系统使用 Python 的 importlib 将 Querybook 与 Pinterest 的内部系统集成在一起。开发人员可以使用插件系统配置认证、自定义查询引擎并实现对内部站点的导出器。插件系统提供的自定义行为让 Querybook 可以针对用户在 Pinterest 上的工作流程做出优化,同时确保开源项目适合大众使用。

 

你可以在 Querybook.org 上查看 Querybook 的更多特性及文档,也可以通过 querybook@pinterest.com 与我们联系。

 

原文链接:https://medium.com/pinterest-engineering/open-sourcing-querybook-pinterests-collaborative-big-data-hub-ba2605558883

2021-04-29 14:192506

评论

发布
暂无评论
发现更多内容

SDWAN组网基于软件,部署灵活且周期短

Geek一起出海

博睿数据率先发布HarmonyOS NEXT系统的应用异常观测SDK

博睿数据

分布式存储技术:总结2023,展望2024

黄岩

分布式存储 zstorage 全闪分布式

2024年中国(北京)国际智能锁产品展会

秋硕展览

数据价值在线化,TiDB 在企查查数据中台的应用

编程猫

万字干货-京东零售数据资产能力升级与实践

京东零售技术

大数据 数据资产

喜报!博睿数据荣获中信银行2023年度优秀服务伙伴奖

博睿数据

80% 的学校还在给新生上 C 语言,是它们 OUT 了吗?

算法的秘密

代码人生

掌握Python编程与ChatGPT的强强联手:开启人工智能助手新时代

快乐非自愿限量之名

Python 人工智能 编程开发 ChatGPT

文心一言 VS 讯飞星火 VS chatgpt (199)-- 算法导论15.2 1题

福大大架构师每日一题

福大大架构师每日一题

已解决error: legacy-install-failure异常的正确解决方法,亲测有效!!!

小明Java问道之路

新型储能|储能电站|2024山西国际储能产业展会

秋硕展览

跃迁:从普通到卓越的成长路径

老张

个人成长

龙年大吉,新的一年开启你的职业飞跃之旅

亚马逊云科技 (Amazon Web Services)

架构师 亚马逊云科技 培训与认证

京东app商品详情数据接口

tbapi

京东 京东商品详情接口 京东API 京东APP商品详情接口

大模型+影像:智能手机“上春山”

脑极体

AI

AP引擎助力加速生产SQL运行

GreatSQL

数据库 ap greatsql

《数字化运维路线图》第四部分-数字化运维转型场景 震撼发布!

博睿数据

2024太阳能产品展|2024山西国际供热采暖展会

秋硕展览

Java 构造函数与修饰符详解:初始化对象与控制权限

小万哥

Java 程序人生 编程语言 软件工程 后端开发

一款高输出电流 PWM 转换器

智趣匠

这份攻略帮助你分分钟构建出“幻兽帕鲁游戏”极致体验

极狐GitLab

OpenLDAP 接入 NineData SSO

NineData

SSO openldap 单点登录 NineData phpLDAPadmin

中国大型企业数字化升级路径研究

快乐非自愿限量之名

已解决UnicodeDecodeError: ‘utf-8‘ codec can‘t decode byte 0xa1 in position 0: invalid start byte异常的正确解决

小明Java问道之路

喜报,喜报!MO 荣获六个年度大奖!

MatrixOrigin

数据库 云原生 分布式,

哈希竞猜游戏开发源码部署方案

西安链酷科技

哈希竞猜 哈希尾数

全新市场周期推动 LaunchPad 迎新起点, Penpad 成新兴生力军

西柚子

2024年工业展|2024越南国际工业技术装备展会

秋硕展览

链接Web3和公链的中间件Smart Layer (SLN)是什么

币离海

strk SLN pixel Smart Layer

4家券商综合评级上升,1月券商App终端业务体验评测报告发布

博睿数据

开源Querybook:Pinterest的大数据协作枢纽_语言 & 开发_Pinterest Engineering_InfoQ精选文章