写点什么

LinkedIn 数据基础设施简介

  • 2010-08-19
  • 本文字数:1180 字

    阅读完需:约 4 分钟

来自 LinkedIn 的 Jay Kreps 在近日举办的 Hadoop 峰会上详细介绍了 LinkedIn 对数据的处理方式。Kreps 介绍了 LinkedIn 每天是如何处理 1.2 千亿个关系并通过高容量、低延迟的站点服务来混合大量的数据计算的。

LinkedIn 的很多重要数据都是离线的,移动起来相当慢。因此,他们将每天对 Hadoop 的批处理作为计算的重要组成部分。比如说,他们采用这种方式对其“People You May Know”产品数据进行预计算,这么做每天会在 mapreduce 管道(拥有 82 个 Hadoop job)中产生 1.2 千亿个关系,需要 16TB 的临时数据。这个 job 使用了一个统计模型来预测两个人认识的概率。有趣的是,他们使用布隆过滤器(bloom filters)来加速巨大的连接关系,这提升了10 倍的性能。

LinkedIn 有两个工程师从事这个管道开发,他们每周可以测试 5 个新算法。为了实现这种变化率,他们使用 A/B 测试来比较新旧方法,使用“fly by instruments”方法来优化结果。为了提升性能,他们还需要操纵大范围数据:使用大范围集群处理。为了实现这个目标,他们从客户化的图处理代码迁移到了 Hadoop mapreduce 代码上:这需要一些周全的设计,因为很多图算法无法直接转换为 mapreduce。

LinkedIn 对开源项目投入巨大,希望构建出一流的组件并号召社区参与进来。其中两个开源项目构成了其数据基础设施的中心。 Azkaban 是个面向 Hadoop 的开源工作流系统,提供了类似于 cron 的调度,类似于 make 的依赖分析,还包含了重启。它用于控制 ETL job,该 job 可以将数据库与事件日志推送到边缘服务器存储(Voldemort)中。

Voldemort 是 LinkedIn 的 NoSQL 键 / 值存储引擎。它每天都会向其站点推送出几十亿的边缘概率关系图,用于渲染网页时查询所用。这种数据是只读的:它是通过这些集群 job 计算出来的,但之后会实时通过搜索进行过滤,这么做会限定到用户感兴趣的某些公司,或是排除掉用户已经表明不认识的那些人。这个方法来源于使用数据库解决这个问题时所遇到的障碍,后者需要分片并迁移至完全依靠手工移动数据的系统。Voldemort 完全是分布式且去中心化的,支持分区与容错。

LinkedIn 通过同时获取 Hadoop 与 Voldemort 大范围的结果来更新服务器,预热缓存,然后分别在每个服务器上针对新一天的数据建立原子转换。他们会将前一天的数据保持在服务器上,这样一旦新一天的数据集出现了问题就可以立刻恢复过来。LinkedIn 在其 Hadoop 管道上构建了一个索引结构:这会产生几个 TB 的查找结构,该结构完美地使用了散列(每个键只需要 2.5 个位)。这种处理权衡了集群计算资源以实现更快的服务器响应;LinkedIn 大约需要 90 分钟时间在 45 个结点集群上构建 900GB 的数据。他们使用 Hadoop 来处理大块的批数据,这样其 Hadoop 集群就需要周期性地进行升级,但 Voldemort 则永远不需要。

感兴趣的读者可以查看演讲的幻灯片以进一步了解详情。

查看英文原文: LinkedIn’s Data Infrastructure

2010-08-19 09:553775
用户头像

发布了 88 篇内容, 共 269.6 次阅读, 收获喜欢 9 次。

关注

评论

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

HarmonyOs基础入门02

flfljh

反向海淘与反向代购的盈利之道及代购系统建站挑战

代码忍者

代购系统 跨境独立站

深度学习的下一站:解锁人工智能的新边界

天津汇柏科技有限公司

深度学习 AI 人工智能

“全球金牌敏捷课程” · 12月28-29日CSM认证课程 · Jim老师引导讨论AI & Agility话题

ShineScrum

第78期 | GPTSecurity周报

云起无垠

harmony_flutter_orientation_plugins(监听屏幕状态插件)

flfljh

鸿蒙+next+判断+Swiper+是否在最后一个元素并向右滑动与在第一个元素并向左滑动

flfljh

鸿蒙+next+实现知识点列表的重复布局

flfljh

鸿蒙+next+使用并封装EmitterUtil

flfljh

鸿蒙JSON对象里面的Map类型的数据如何接收

flfljh

harmony_flutter_keyboard_visibility(监听动态键盘)

flfljh

鸿蒙ArkWeb 跨域请求

flfljh

VMware Workstation 17.6.2 Pro Unlocker & OEM BIOS 2.7 for Windows & Linux

sysin

Workstation

鸿蒙应用开发从入门到入行 - 篇3:ArkUI布局基础与制作可交互页面

猫林老师

鸿蒙 HarmonyOS 鸿蒙应用开发 HarmonyOS NEXT

msprofiler前置知识:如何看懂tracing profile文件?

zjun

性能 debug Trace

鸿蒙next中Web的使用

flfljh

Ascend Extension for PyTorch的源码解析

zjun

模型 PyTorch Ascend

harmony_flutter_videoCompress(视频压缩)

flfljh

harmony_flutter_更新Flutter插件项目结构

flfljh

鸿蒙Flutter之解析flutter相关的cppcrash堆栈

flfljh

《Django 5 By Example》阅读笔记:p614-p644

codists

Python django

鸿蒙+next+实现试卷计时器

flfljh

鸿蒙+next实现页签栏平板端适配

flfljh

鸿蒙Flutter性能调优分析之帧渲染跟踪

flfljh

鸿蒙开发:前端页面调用 ArkTS 函数全解析

flfljh

Splunk Enterprise 9.4 发布,新增功能概览

sysin

Splunk Enterprise

横竖屏切换开发实践

flfljh

鸿蒙Flutter性能调优之滑动响应时延

flfljh

鸿蒙应用开发从入门到入行 - 篇3:ArkUI布局基础与制作可交互页面

猫林老师

鸿蒙 HarmonyOS 鸿蒙应用开发 鸿蒙原生应用开发 HarmonyOS NEXT

安全架构师的自我修炼:从原则到实践

I

安全架构师 信息安全 安全设计 企业安全 安全架构设计

Ascend Extension for PyTorch是个what?

zjun

PyTorch CANN Ascend

LinkedIn数据基础设施简介_架构_Ron Bodkin_InfoQ精选文章