当前位置:首页 > 智能硬件 > 人工智能AI
[导读] 数据科学家与DevOps工程师相互协作可以获得更好的业务成果,但了解他们的不同需求是关键。 数据科学家与软件开发人员有一些共同的实践和需求。数据科学家和软件工程师都计划、构建、编码、迭代

数据科学家与DevOps工程师相互协作可以获得更好的业务成果,但了解他们的不同需求是关键。

数据科学家与软件开发人员有一些共同的实践和需求。数据科学家和软件工程师都计划、构建、编码、迭代、测试和部署代码来实现他们的目标。对于软件开发人员来说,这通常意味着自定义编码应用程序和微服务;数据科学家实现与数据操作的数据集成,通过分析模型进行预测,并创建仪表板以帮助最终用户导航结果。

那些寻求自动化,并与运营工程师开展合作的Devops工程师应该扩大其业务范围,并向数据科学家提供服务。

拥有多个数据科学团队的大型组织可能会投资于Alteryx Analytics、Databricks、Dataiku等数据科学平台,这些平台提供了用于开发、测试和部署分析模型的混合工具。这些工具在数据集和分析功能、集成选项、治理、业务用户工具和部署选项上展开激烈的竞争。

DevOps对数据科学家的要求与应用程序开发人员不同

并非每个组织都对投资数据科学平台做好了准备,或者可能只需要基本操作能力的小型数据科学团队。在这些情况下,最好将DevOps最佳实践应用于数据科学团队,而不是选择和使用平台。

为此,许多用于软件开发团队的敏捷和开发范例可以应用于数据科学工作流程,并进行一些重大调整。虽然数据科学家的流程与开发人员的工作流程类似,但存在一些重要的区别。

•数据科学工作需要围绕数据集、模型和配置进行更多实验。这不是大多数软件开发商发布管理实践遵循的简单计划、构建、测试、部署周期。

•开发和测试模型可能无法使用统一的计算堆栈。一些模型可以使用简单的Python脚本实现,而其他模型可以使用Apache Spark和其他大数据平台。

•即使模型处于开发阶段,计算需求也会有很大差异。例如,一位数据科学家想要针对一个大数据集测试一个模型的六个变体,与另一位在一个规模较小数据集测试一个模型的数据科学家相比,需要更多的计算能力和存储容量。

•部署到生产中的模型也需要持续维护,但除了更改底层代码之外,还有更多变量。模型还需要使用更新的数据集进行重新训练、重新配置操作参数以及调整基础设施,所有这些都可能触发新的部署。

监控数据管道通常需要更复杂的验证。知道数据操作过程正在运行,并且模型正在处理数据是不够的。这些工具一旦投入生产,就必须对吞吐量、错误条件、数据源异常以及可能影响下游结果的其他条件进行监控。

•要想取得成功,数据科学家必须与开发人员、工程师、业务负责人合作,这与在应用程序开发中巩固开发人员和操作人员之间的协作相比,可能是一项更艰巨的任务。此外,许多数据科学家和团队可能不会向IT组织报告,因此更难为这些组织制定标准和治理。

在开始采用DevOps实践和解决方案之前,支持数据科学家需要了解这些和其他差异。

从数据科学家的经验开始

与应用程序开发人员一样,数据科学家最感兴趣的是解决问题,他们非常关注配置工具,但对配置基础设施的兴趣往往更少。与软件开发人员不同,数据科学家可能没有相同的经验和背景来充分配置他们的开发工作流程。这为DevOps工程师提供了一个将数据科学家视为客户,帮助他们定义需求,以及拥有交付解决方案所有权的机会。

这可以从数据科学家需要的基础设施开始。他们是用Python、R还是其他语言编写代码?他们使用什么工具(Jupyter、Tableau、Apache Kafka和NLTK)进行分析和建模?他们使用哪些数据库和云平台作为数据源,用于存储经过训练的数据,以及用于部署模型?

为此,DevOps工程师可以帮助数据科学家选择和标准化开发环境。这通常可以在计算设备或虚拟桌面上完成。无论哪种方式,将他们的应用程序和配置镜像到开发环境是与数据科学家进行合作的重要的第一步。

在此之后,DevOps工程师应该检查数据科学家存储代码的位置、代码的版本控制方式,以及代码如何为部署打包。例如,一些数据科学家对使用版本控制工具(如Git)相对较新;另一些数据科学家可能使用代码库,但没有实现自动化集成。实现持续集成是DevOps工程师帮助数据科学家的第二个方面,因为它创建了标准,并删除了测试新算法的一些人工工作。

需要记住的一点是,某些SaaS和企业数据平台可能具有内置版本控制,并且不会自然地与为代码设计的版本控制系统接口。其中许多平台都有API来触发集成和部署或其他可以模仿持续集成(CI)/持续交付(CD)管道的机制。

定义部署管道并配置基础架设施

在开发环境和持续集成标准化的情况下,DevOps工程师应该考虑自动化测试和生产环境的其他方面。这可以通过使用Jenkins等工具引入部署管道,并使用Chef、Puppet、Ansible或其他工具将基础设施配置为代码来实现。

数据科学环境也是Docker等容器以及Kubernetes等容器管理和编排工具的有力候选者。数据科学环境通常是数据操作、数据管理和数据建模平台的组合,这些平台需要作为集成环境进行部署和管理。

了解运行数据集成、机器学习培训和其他数据分析工作的规模和频率至关重要。DevOps工程师很可能会发现多种模式,因为数据科学家混合了不同的工作负载,例如,对部分数据集频繁测试新模型、计划运行以重新培训生产机器学习模型,以及培训新分析模型的特殊工作。这些工作负载类型应该帮助DevOps工程师决定如何最好地配置和扩展云计算基础设施,以满足不同的计算和存储需求。

开发人员、DevOps工程师和数据科学家还应该就业务成果进行协作。

实现DevOps的最重要方面是促进具有冲突目标的开发人员和DevOps工程师之间的协作。开发人员经常面临着更改应用程序的压力,DevOps工程师需要对生产工作流的性能和可靠性负责。让开发人员和工程师在自动化和标准化配置方面进行协作可以实现这两个目标。

数据科学家是这次合作的第三方。他们经常面临向高管和业务经理提供分析结果的压力。其他时候,他们正在开发模型,希望开发人员在他们的应用程序中使用这些模型。他们对可变容量基础设施有着强烈的需求,在试验新平台、库和基础设施配置时,他们可能比开发人员要求更高。

数据科学家需要与开发人员和工程师建立这种合作关系,以提供成功的分析成果。而了解他们的目标、定义目标以及在DevOps实现上进行合作是这些团队如何协作和交付业务成果。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭