当前位置:网站首页>Spotify是如何推动数据驱动决策的?
Spotify是如何推动数据驱动决策的?
2020-11-08 08:26:00 【InfoQ】
Spotify的基础设施团队分享了他们是如何通过对数据进行优先级排序来构建一个自动化的数据收集平台,从而在DevOps中实现了数据驱动决策,并提高了开发人员的生产效率和产品价值的。
Spotify的基础设施团队使用Gradle(Gradle Enterprise Edition)作为其Android应用程序的构建系统。它能生成、收集和存储需要根据本地开发经验来理解软件所需的数据。它需要共同关注数据管道和仪表板的可视化。对于iOS系统数据的生成、收集和存储,目前还没有一个成熟的解决方案,所以该团队自己开发了这些工具。
Spotify在数据领域已经投入了很长一段时间了。Spotify的技术学习团队推出了数据大学(Data University),这是一系列涵盖数据科学和工程学各个方面的培训课程,旨在帮助工程师解决与产品相关的问题。
Android基础设施团队将这些经验教训运用到他们的构建时间和本地开发经验中,但他们发现他们缺乏驱动决策的数据。
Spotify通过召集某些特定“部落”小组来专门提供数据基础设施,并为工程师配备构建模块来收集数据并可视化数据输入,从而解决了这种数据需求。他们指出,目前仍然存在许多挑战,例如如何将这种数据驱动的方法应用到他们的架构决策中。
该团队使用这一新的数据基础设施来阐明技术和产品团队应该在哪些方面进行投资来减少构建时间。当他们查看构建时间趋势以及Swift和ObjC中使用的组件总数时,他们认识到投资于Swift优化是有意义的。
这项针对数据驱动决策的技术投资与哈佛商业评论分析服务公司(Harvard Business Review Analysis Services)最近的一项研究结果截然不同,该研究显示,只有7%的企业为其团队提供了推动基于数据的决策和自主权所需的分析工具和资源。
从本质上讲,Spotify的方法很简单:团队提出他们解答不了的问题,然后在积压的待办事务中(backlog)优先处理这些问题。在数据可用且问题得到解答之后,团队在评估阶段收集反馈,以了解该工作是否对本地开发过程产生了影响。为了防止数据质量的恶化,团队必须对每个组件的数据一致性和数据管道进行质量检查。
在计划阶段,团队使用历史数据来确定需要改进的场景。这些数据可能无法描述当前的情况,但它提供了确定改进的基线。如果他们已经了解了特定情况下系统的构建时间,那么他们希望保持相同的数值,或者改进这些数值,而不管代码库的增长情况是怎样的。这一点是至关重要的,因为随着系统变得越来越复杂,DevOps工作流通常也会变得复杂且不透明。
敏捷自然倾向于优先考虑产品,因此DevOps面临的挑战是,如何在增加特性以提高产品效率和提高开发效率或提高服务可靠性之间找到折衷点。
在计划阶段,团队引入了一些任务来收集和显示验证更改所需的数据。此阶段提出的问题是关键的输出之一,例如:“我们是否收集了足够多的信息来检查开发人员是否打开了远程缓存?”或者“在单个PR中他们平均更改了多少个组件?”
随着基础设施团队的数据计划在内部得到更广泛的认可,其他团队开始优先考虑与平台相关的工作。产品团队开始重视数据可视化,以验证驱动移动DevOps团队决策过程的产品讨论。
产品团队的数据驱动决策有助于评估解决方案的有效性和采用的满意度。产品经理通常从早期阶段就开始使用用户调查来评估产品了。相比之下,数据驱动的过程将这种评估带到了产品概念化中。
InfoQ的数据驱动决策系列概述了数据驱动决策是如何支持软件交付中的三个主要活动的——产品管理、开发和运维。
原文链接:
https://www.infoq.com/news/2020/10/Data-Driven-Decisions/
版权声明
本文为[InfoQ]所创,转载请带上原文链接,感谢
https://www.infoq.cn/article/3cJU3UsBzsAIKoVcyCPD?utm_source=rss&utm_medium=article
边栏推荐
- C语言I博客作业03
- 蓝牙2.4G产品日本MIC认证的测试要求
- 什么你的电脑太渣?这几招包你搞定! (Win10优化教程)
- Unparseable date: 'Mon Aug 15 11:24:39 CST 2016',时间格式转换异常
- Python learning Day1 -- Basic Learning
- python学习 day1——基础学习
- 微信昵称emoji表情,特殊表情导致列表不显示,导出EXCEL报错等问题解决!
- More than 50 object detection datasets from different industries
- Simple use of future in Scala
- What details does C + + improve on the basis of C
猜你喜欢
C++基础知识篇:C++ 基本语法
M-end software product design considerations - Zhihu
Mate 40系列发布 搭载华为运动健康服务带来健康数字生活
双向LSTM在时间序列异常值检测的应用
IOS learning note 2 [problems and solutions encountered during the installation and use of cocopods] [update 20160725]
Ulab 1.0.0 release
分布式共识机制
More than 50 object detection datasets from different industries
将“光头”识别为“足球”,AI 摄像头如何犯的错?
ASP.NET A complete solution based on exception handling in MVC
随机推荐
Qt混合Python开发技术:Python介绍、混合过程和Demo
nvm
wanxin金融
QT hybrid Python development technology: Python introduction, hybrid process and demo
vivoY73s和vivoY70s的区别 vivoY73s和vivoY70s哪个值得入手
FORTRAN 77 reads some data from the file and uses the heron iteration formula to solve the problem
Codeforce算法题 | 你能想出解法,让你的基友少氪金吗?
The software in your host has terminated an established connection. resolvent
China Telecom announces 5g SA commercial scale in 2020
将“光头”识别为“足球”,AI 摄像头如何犯的错?
Visual studio 2015 unresponsive / stopped working problem resolution
shiyou的数值分析作业
ubuntu实时显示cpu、内存占用率
Application of bidirectional LSTM in outlier detection of time series
5g + Ar out of the circle, China Mobile Migu becomes the whole process strategic partner of the 33rd China Film Golden Rooster Award
Littlest JupyterHub| 02 使用nbgitpuller分发共享文件
PCR and PTS calculation and inverse operation in TS stream
Goland 编写含有template的程序
LadonGo开源全平台渗透扫描器框架
0.计算机简史