首页 > 其他分享 >字节跳动基于DataLeap的DataOps实践

字节跳动基于DataLeap的DataOps实践

时间:2023-08-23 11:00:44浏览次数:46  
标签:DataOps 字节 研发 BP DataLeap 团队 数据

更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群

本文根据 ArchSummit 全球架构师峰会(深圳站)来自抖音数据研发负责人王洋的现场分享实录整理而成(有删减),本次分享主要包含字节跳动数据研发的模式与挑战、DataOps理念在字节的具象 、DataOps产品化及落地、最佳实践、未来展望五个部分,分享内容皆来自于字节跳动业务实践经验。

字节跳动数据研发的模式与挑战

中台工具+数据BP模式

字节在落地DataOps的过程当中,与我们数据支持所采用的中台工具+数据BP的组织模式相结合,由中台工具团队负责打造功能的基座,实现了数据开发的各项基础能力并提供开放平台,对数据BP团队提供贴身的技术支持,同时也将这些能力通过火山引擎以内外一体的模式输出。所谓的内外一体是指字节的各类数据工具如DataLeap在面向内外部用户使用上实现了一致性。

对于数据BP团队来说,在落地DataOps的过程中,重点做了三件事情:第一件事是规范的制定,在字节内部长期实践过程中,我们认为实践团队才是规范的最佳发源地;第二件事是基于中台工具的开放平台实现插件的开发,数据 BP并不是一个纯数仓团队,其中也包含了部分工程团队,与数仓一体的工程团队可以将数仓日常的痛点以插件的形式实现并落地,不同数据BP团队可以根据自己的特点开发不同插件;最后一件事是收益评估,DataOps推广完了之后,也是放在 BP 来评估,而不是放在平台来评估,中台工具团队就可以专注于能力本身,开发数据 BP 团队专注于整个规范跟价值。最后外部客户可以同时享受到我们的平台能力,以及沉淀下来的 BP 模式,这就是字节整个团队在DataOps上落地的协作模式。

数据BP的核心指标:0987

字节跳动基于DataLeap的DataOps实践_开放平台

数据BP团队做的好坏与否如何来评估,我们用了一套浅显易懂的指标0987来评价

0指不要出数据事故,这里的事故包括了时效、质量等问题,由于我们支持了较多线上和资损场景,事故在我们的评价体系中是生命线;

9指需求满足率,我们承接了来自多方的数据需求,希望能达成90%以上的需求我们都能按期交付的目标;

8指分析覆盖率,这个指标指外部团队基于数仓的查询能80%使用到经过我们建设和汇聚的表,而非原始表;

7指NPS 指标,我们每个季度会面向所有提需用户和数据使用用户发放问卷,收集对应的反馈信息,70%意味着大部分的同学对我们持正向评价且负向评价趋近于0;

来自质量挑战

在字节数据团队当前的支持模式下,由于支持模式多种多样,覆盖了各类核心决策及线上场景,我们遇到的首要挑战是来自数据质量的:

  • 链路复杂:最长任务全链路节点数量上千个,单个任务的的下游数量最大也达到了千级别
  • 变更频繁:每周仅直播数据团队数据链路变更次数就能达到上千次,涉及风险场景上百次
  • 事故易发:质量事故时有发生22年全年数据研发事故涉及到研发规范的占比56%

来自硬件成本的挑战

在降本增效大背景下硬件成本也逐步变成数据团队的一个核心挑战,在过去我们控制成本与大多数公司一致,主要基于预算,先测算出一个全年计算和存储资源目标,然后基于预算开展治理动作,清理无效任务或降低TTL;但是现在需要朝着需求的精细化控制方向前进,需要进一步看清楚我做这个需求需要多少硬件成本,从而将硬件成本的管控精细化到需求层面

来自人效的挑战

除去硬件成本外,我们的另一个成本大头就是人力成本,我现在带一个数据研发团队,在每次进行HC盘点的时候我都会遇到两个灵魂提问:

  • 如何证明团队当前的状态是高效的?
  • 如何用更少的人员创造更大的业务价值?

这其实是一个很现实的挑战,我们如何证明一个数据团队它的价值是什么?

DataOps理念在字节的具象

既然面临着这么多的挑战,我们就要去思考如何能够突破这些挑战,从业内取经,我们发现DataOps就是一种能够有效帮助我们解决上述问题的方案

信通院关于DataOps的定义

  • 数据研发运营一体化(DataOps):是数据开发的新范式,将敏捷、精益等理念融入数据开发过程,通过对数据相关人员、工具和流程的重新组织,打破协作壁垒,构建集开发、治理、运营于一体的自动化数据流水线,不断提高数据产品交付效率与质量,实现高质量数字化发展。

我们的理解

  • DataOps是作用于人+流程+工具的一套方法论,目标是提高数据质量和开发效率,主要通过敏捷协作、自动化/智能化、以及清晰的度量监测,让数据流水线达到持续集成、部署、交付(CI/CD),在DataLeap体系内,DataOps主要以规范研发流程为目的,涵盖对规范研发流程的“已有能力集成”,形成一站式研发体验,同时也包括规范研发流程所需关键的“新能力建设+集成”,除此以外的数据开发基础能力迭代不作为DataOps的一部分

字节跳动基于DataLeap的DataOps实践_链路_02

我们认为 DataOps 的核心包括以下部分

第一个是链接,所谓的链接是要打通从需求、开发、资产、用户整个数据全链条的绑定关系。从功能上来讲它比较简单,解决了需求与代码的关系问题,业务研发侧早就已经实现了这个能力,研发人员提交的每一段代码,都能知道是哪个需求。但是在数据开发这件事情上,过去缺乏关注,所以首先需要做的事情是连接需求跟数据全环节。

第二个是规范,过去数据研发整个全流程较为缺乏规范的产品化,主要通过团队内部的文档要求来承载,包括提需评审、模型开发测试、上线验收这些环节,我们认为 DataOps在规范上面最首要的事情是要把所有数据研发过程中的这些散落的规范产品化并嵌入到日常的开发链路中。

DataOps产品化及落地-DataLeap


字节跳动基于DataLeap的DataOps实践_数据研发_03

这张图展现的是字节数据开发的dataleap套件能力,涵盖了计算引擎、全链路开发、全域治理、资产等工具,这样的一站式大数据开发套件,能够帮助用户快速完成数据集成、开发、运维、治理、资产、安全等全套数据研发工作,帮助数据团队有效的降低工作成本和数据维护成本、挖掘数据价值、为企业决策提供数据支撑。DataLeap不是一个产品,是一个套件(Suite)。形象的类比就是类似Office,多个产品相互配合,解决同一个大的问题或者叫解决方案,产品之间是相互合作辅助的关系。

DataOps敏捷规范研发平台

字节跳动基于DataLeap的DataOps实践_数据中台_04

这是字节整个 DataOps 的产品化的整体框架图,核心提供的一套DataOps敏捷规范研发平台。以前有一种模式是平台团队自己全包,把这些所有的规范全部给制定好,由平台团队推给数据开发团队,但这种模式不太适合我们,因为平台团队离业务远。

我们认为在这种情况下平台应该选择优先提供开放的能力,这里的开放能力包括开放数据与接口、开放流程等等,有了这套开放能力,意味着所有的数据开发团队可以自己去编排流程,去做自己的规则规范。

另外我们发现开发团队做好之后,这套DataOps敏捷规范研发平台在所有的数据开发团队都通用,举个例子,测试的能力在字节不是在平台做的,有专门的数据 BP 团队,实时这块有特殊诉求:发布完了之后数据要做盯盘,盯住实时数据的变化。依托开放平台提供的数据支持,在直播场景下会提供给到主播一些实时的数据,去辅助他们做及时的决策。这些实时数据包括用户的数据、用户的画像等等,主播可以基于这些用户的画像去调整话术。基于开放平台 ,数据BP团队做任务的整个发布能力,之后我们发现这套能力可以通用。

需求管理

字节跳动基于DataLeap的DataOps实践_开放平台_05

简单的给大家看一下字节现在已经上线的内部版本的功能,包括了需求管理的各个维度,当然需求管理这里其实核心的思路是让需求能够进入到数据研发的全流程当中,大家可以看到我们会做需求的准入要求,以及跟开发过程以及交付绑定,然后需求的进度追踪、价值评估等相关的一些事情,这是一个标准需求流水线,是字节需求管理平台上的一套流程,就是从需求开始,初评、详评、排期、研发验收、价值反馈结束。

这是需求绑定页面,在做任务开发的时候需要对当前的一些需求做绑定,当然这只是提供了需求绑定开发环节的一个图,我们也会有包,比如说资产环节以及任务环节等各种修改环节都会跟需求做绑定。这个功能很简单,但是需求的全链路串联为字节带来的收益非常大,解决了第一个是可度量所有全流程的问题。

流水线管理

字节跳动基于DataLeap的DataOps实践_开放平台_06

第二个是流水线管理,字节的流水线管理包括测试流水线、发布、离线、实时任务管理、任务优先级管理等相关的能力,这是现在线上跑的一个任务,跑完的流水线的状态,就发布会做登记、检测、检查、review,然后定时发布任务、盯盘等确认等相关的动作。

重点讲一下这里的发布跟测试环节,这两块在很多公司其实是有测试环境的,但是在数据量特别大的场景和数据,或者较为复杂的场景下测试环境是没数据的。测试环境跟业务研发相比,没办法涵盖各种各样的问题,比如说银行场景下测试环境和生产环境肯定是隔离的,但是在字节这种互联网场景下我们的选择是不分离,我们的发布和测试其实是基于的是同一套数据,同一套环境,那如何做测试跟生产的一个隔离?核心点在于我们要求所有没有经过发布流水线的任务是不能写生产的表的,读任何生产的表,但是不能写任何生产的表。这样带来的好处是我们的测试和生产是完全一致的,同时也能保证测试完了之后直接推到生产上去,这样下来后面的测试、 QA 介入的成本是极其低的,这是字节采用的一种方式。

最佳实践

推广运营:如何在公司范围内大规模落地DataOps?

做了这些工具之后要如何去推广?这也是今年初字节面临的问题,就是如何在公司内大范围去落地 DataOps 的能力。最早开始推得很辛苦,也遭遇了很多挑战,不过也总结了一些经验。

鲶鱼效应

第一个叫做鲶鱼效应,所谓的鲶鱼效应因为是数据BP 在主导这件事情,所以主导团队可以先推起来。比如说在直播场景下先试用拿到非常多的指标,总结经验,我们可以带着这些指标和经验去和其他团队沟通,以提高人效的角度切入,在这种情况之下,有的团队就会愿意来学习试用。

拆箱即用

第二个是拆箱即用,我们向其他 BP 团队提供的时候,其他 BP 团队不需要多做任何其他的事情,只需要打开他的流程开关就 OK 了,切换路径成本是非常低的。

自顶向下

第三个是自顶向下,类似的像 DataOps 这种工具跟能力,一定是需要先拿到自顶向上,或者是来自于业务侧更高层的认可之后,才能够持续不断地往下推,类似规范的事情,不是一个自下往上能推得起来的。

指标牵引

一个研发 leader 肯定会关注研发效能问题,这里给大家分享一套字节基于研发效能的指标牵引体系,该体系有四个维度的度量指标,包括效率、质量、资源投入、收益等相关的一些指标。这些指标是我们参照业务研发来形成了一套数据研发指标体系,我们会去关注数据需求的交付周期、定容率、交付数、缺陷修复时长、线上事故、业务研发的配比。最后是重点专项相关的一些事情。这里面除了最后一个是需要人工去干预的,其余的现在都能做到线上化的统计,这是非常方便的。

管理者视角

所谓管理者视角是围绕数据开发团队的价值和未来,通过开放让数据团队有可输出的专业价值。对于数据团队来讲有两类价值,一类叫做业务价值,一类叫做专业价值。业务价值很好讲,是我为业务做了多少个需求,其中哪些重点项目重点参与了,最后是为业务带来了多少效率上的提升,通过某些数据的手段让业务拿到了多少收益。其次是专业性的价值,这个事情对于很多数据团队来讲是一个很困扰的难题,数据团队到底在业界、在公司内部有哪些是不可替代的?有哪些是专业性的东西?这里我们在做 Datops 实践的时候,发现通过开放让数据团队自己有可输出的专业性价值,这非常关键,这能让数据团队很充分地来参与到这件事情当中来。

开发者视角

在开发者视角层面,核心的事情是如何获得工作当中的成就感,这一点是留住人的关键:

  • 认可&执行:规范本身是反人性的,在团队内落地DataOps需要充分沟通,结合团队调整与个人发展,讲清为什么,避免粗暴落地
  • 参与&贡献:构建人人可参与的开发环境,让数据开发可以深度的参与到流程制定与落地的过程中来,促进个人影响力的提升

收益度量

落地DataOps的收益主要包含规范、质量、效率三部分,具体来看:

  • 规范:在不同方向上规范制定与复用,保障流程100%落地
  • 质量:系统性的解决风险场景上的研发流程问题,因研发流程导致的数据质量事故数归0
  • 效率:通过更可靠的交付避免返工,同时叠加提效能力,预计可提升研发在业务需求满足中的开发效率10%+

未来展望

业务价值

最后是关于数据研发未来的展望,首先想谈谈业务价值:

  • 数据需求价值度量标准
  • 基于需求价值最大化的调度策略

数据需求的价值度量相对功能需求而言更为复杂,所以下一阶段我们是希望能够度量清楚数据需求的具体价值,然后实现基于需求价值最大化的调度策略,从而达成我们对于人效和成本的控制目标。

质量与效率

关于质量与效率,未来我们会主要关注以下三点:

  • 基于大模型的需求对接能力
  • 基于大模型辅助开发的能力
  • 低成本的数据测试及验证能力

最近大模型特别火,我们认为大模型参与数据研发是非常具有现实意义且具有挑战的事情,不论从需求对接还是辅助开发视角上,大模型都能为我们提供更多自动化方案应对过去需要依赖经验沉淀才能解决的问题;同时我们发现在字节的数据规模下数据测试的成本是非常高的,未来也希望探索低成本的数据测试的验证方案。

对外开放

字节跳动基于DataLeap的DataOps实践_开放平台_07

DataOps理念在字节落地的成果后续也会通过火山引擎DataLeap对外输出。火山引擎DataLeap是一站式数据中台套件,能够帮助用户快速完成数据集成、开发、运维、治理、资产、安全等全套数据中台建设,帮助数据团队有效的降低工作成本和数据维护成本、挖掘数据价值、为企业决策提供数据支撑。


点击跳转火山引擎DataLeap了解更多


标签:DataOps,字节,研发,BP,DataLeap,团队,数据
From: https://blog.51cto.com/bytedata/7200351

相关文章

  • 图片转base64,base64转图片,图片对象转图片字节,图片字节转图片对象
    demo图片转base64defimage_to_base64(image_path):importbase64withopen(image_path,"rb")asimage_file:image_data=image_file.read()base64_encoded=base64.b64encode(image_data).decode("utf-8")retur......
  • 《深入浅出Java虚拟机 — JVM原理与实战》带你攻克技术盲区,夯实底层基础 —— 吃透cla
    前言介绍了解Java代码如何编译成字节码并在JVM上执行是非常重要的。这种理解可以帮助我们理解程序执行时发生的情况,确保语言特性符合逻辑,并在进行讨论时能够全面考虑各种因素和副作用。本文将深入探讨Java代码编译成字节码并在JVM上执行的过程。如果您对JVM的内部结构和字节码执行......
  • 开发调试更便捷!火山引擎 DataLeap 提供 Notebook 交互式开发体验
    更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群Notebook是一种支持REPL模式的开发环境。所谓「REPL」,即「读取-求值-输出」循环:输入一段代码,立刻得到相应的结果,并继续等待下一次输入。Notebook通常使得探索性的开发和调试更加便捷,在Notebo......
  • 开发调试更便捷!火山引擎 DataLeap 提供 Notebook 交互式开发体验
    更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群 Notebook是一种支持REPL模式的开发环境。 所谓「REPL」,即「读取-求值-输出」循环:输入一段代码,立刻得到相应的结果,并继续等待下一次输入。Notebook通常使得探索性的开发和调试更加便......
  • 【补充】字符与字节的区别
    在计算机编程中,字符(Character)和字节(Byte)是两个有关数据表示和处理的重要概念。【一】字符(Character):字符代表着某种可视或可打印的符号,例如字母、数字、标点符号、特殊符号等。在计算机内部,字符使用字符编码来表示,最常见的字符编码是ASCII(AmericanStandardCodeforIn......
  • Oracle 12C 新特性-扩展数据类型,在12c中,与早期版本相比,诸如VARCHAR2, NAVARCHAR2以及
    1.查看参数max_string_size默认值SQL>showparametermax_string_sizeNAME                   TYPE                 VALUE---------------------------------------------------------------------......
  • iwebsec-sql注入 06 宽字节字符型注入
    01、题目分析宽字节字符型注入,因为源代码中传参get值的时候,有一个addslashes()函数,是返回在预定义字符('")之前添加反斜杠的字符串。也就是说,当我们按照正常的字符型注入的时候,会在'前加入,也就是说,我们在url上--url写入?id=1'orderby3--+--在addslashes(1'order......
  • 挖掘优质短视频超百万条,火山引擎DataLeap助力电商平台生态治理
    更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群在人们的日常生活中,网购已经成为人们生活中不可或缺的购物形式。根据《中国社交电商行业发展白皮书(2022)》的数据显示,2022年社交电商市场交易规模达到28542.8亿元,预计2023年中国社交电商行业交易规......
  • 字节码增强
    (文章目录)Java字节码增强前言Java字节码增强是一种在Java字节码级别上修改和增强Java应用程序的技术。它可以被用于多种场景,例如在应用程序的运行时进行动态的修改和增强,或者在编译时根据特定的需求进行静态的修改和增强。本文将从一个故事开始,通过讲解Java字节码增强的原理,技......
  • Golang 高效并发安全的字节池
    记录一下,这里学的BytePoolCap,和sync.Pool总之就是这个BytePoolCap比sync.Pool快一些,目前不会测试,后面测试了再来填坑。packagemainimport( "fmt")funcmain(){ // varbpoolBytePoolCap bp:=NewBytePoolCap(500,1024,1024) buf:=bp.Get() deferbp.Put(buf......