【大模型从入门到精通40】LLM部署运维(LLM Ops)使用Kubeflow Pipelines掌握LLM工作流2

news2024/9/22 1:37:00

这里写目录标题

      • 使用Kubeflow Pipeline组件:输出与任务对象
        • 理解PipelineTask对象
        • 通过PipelineTask.output访问输出数据
        • 组件函数中的关键字参数
        • 实用贴士
      • 在Kubeflow Pipelines中链接组件:传递输出
        • 定义依赖组件
        • 传递组件输出
        • 常见错误:传递正确的对象类型
        • 实用贴士

在这里插入图片描述

使用Kubeflow Pipeline组件:输出与任务对象

在定义了带有@dsl.component装饰器的Kubeflow Pipeline组件之后,理解函数在管道上下文中如何工作是非常重要的。与直接返回特定数据类型的典型Python函数不同,带有@dsl.component装饰器的函数在管道中被调用时表现得略有不同。

理解PipelineTask对象

当你调用一个定义为Kubeflow Pipeline组件的函数时,它不会直接返回预期的数据(如字符串或整数),而是返回一个PipelineTask对象的实例。这个对象代表了组件在管道中的执行,并可用于将数据传递给后续的组件。

# 将组件函数的结果赋值给变量
hello_task = greet_person(name="Erwin")
print(hello_task)

在这段代码中,greet_person(name="Erwin")并不会直接返回问候消息。相反,它返回了一个PipelineTask对象,我们将其赋值给hello_task。打印hello_task将不会显示问候消息,而是会显示关于PipelineTask实例的信息。

通过PipelineTask.output访问输出数据

要在管道中利用组件的输出,我们需要访问PipelineTask对象的.output属性。这个属性允许一个组件的输出数据作为输入传递给另一个组件,从而实现了管道中数据的流动。

# 访问组件的输出
print(hello_task.output)

PipelineTask对象的.output属性将是Kubeflow Pipelines框架识别的基本数据类型之一,如’String’、‘Integer’、‘Float’、‘Boolean’、‘List’或’Dict’。这样可以确保组件间数据交换的兼容性和便捷性。

组件函数中的关键字参数

需要注意的是,在向组件函数传递值时,必须使用关键字参数。这一要求确保了清晰性,并避免了由于位置参数可能引起的错误,尤其是在复杂的管道中,组件可能具有多个输入。

# 这样会导致错误
# hello_task = greet_person("Erwin")

# 正确调用组件函数的方式,使用关键字参数
hello_task = greet_person(name="Erwin")

尝试使用位置参数调用组件函数会导致错误。这样的设计鼓励明确指定参数,增强了代码的可读性并减少了出错的可能性。

实用贴士
  • 明确命名参数: 调用组件函数时始终使用关键字参数。这一做法提高了代码的清晰度,并确保了你的管道定义易于阅读和维护。
  • 管理输出: 记住组件的输出是通过PipelineTask.output属性访问的。仔细规划管道中的数据流,考虑数据如何在组件之间传递。

通过理解Kubeflow Pipeline组件的这些方面,你将更好地装备自己去构建复杂而高效的机器学习工作流。这些原则确保了你的管道既健壮又易于维护且可扩展。

在Kubeflow Pipelines中链接组件:传递输出

基于我们对Kubeflow Pipeline组件的理解,我们现在将进一步探讨如何创建一个管道,其中一个组件的输出作为另一个组件的输入。这一过程展示了Kubeflow Pipelines在编排复杂工作流方面的强大功能。

定义依赖组件

让我们定义第二个组件,它接收第一个组件(我们的问候消息)的输出,并在此基础上添加一个问题,询问对方近况如何。这个例子说明了如何定义依赖于管道中先前组件输出的组件。

# 导入DSL模块以定义组件
from kfp import dsl

# 定义依赖于另一个组件输出的组件
@dsl.component
def ask_about_wellbeing(greeting_message: str) -> str:
    # 构造一条包含问候和后续问题的新消息
    follow_up_message = f"{greeting_message}. How are you?"

    # 组件返回新消息
    return follow_up_message
传递组件输出

定义了第二个组件后,我们展示如何将第一个组件(greet_person)的输出作为输入传递给第二个组件(ask_about_wellbeing)。这是将组件链接在一起形成工作流的关键步骤。

# 为第一个组件创建任务并存储其输出
greeting_task = greet_person(name="Erwin")

# 将第一个组件的输出传递给第二个组件
wellbeing_task = ask_about_wellbeing(greeting_message=greeting_task.output)
print(wellbeing_task)
print(wellbeing_task.output)

在这段代码中,greeting_task.output被作为greeting_message输入传递给了ask_about_wellbeing。这展示了数据如何从一个组件流向另一个组件在Kubeflow Pipeline中的方式。

常见错误:传递正确的对象类型

重要的是要传递PipelineTask对象的.output属性,而不是PipelineTask对象本身。传递错误的类型将导致错误,因为组件期望的是基本数据类型,而非PipelineTask对象。

# 错误用法:传递PipelineTask对象而不是其输出
# 这将导致错误
# wellbeing_task = ask_about_wellbeing(greeting_message=greeting_task)

# 正确用法:传递PipelineTask对象的输出
wellbeing_task = ask_about_wellbeing(greeting_message=greeting_task.output)
实用贴士
  • 始终传递.output以建立依赖: 在连接组件时,确保你传递的是前一个组件任务对象的.output属性。这是一个常见的错误,但通过仔细的代码审查很容易避免。
  • 单独测试组件: 在将组件集成到更大的管道之前,先单独测试它们以确保它们按预期工作。这种方法有助于在开发过程的早期识别和解决问题。

通过掌握在Kubeflow Pipelines中链接组件的方法,你可以构建复杂而模块化的机器学习工作流,这些工作流易于阅读且灵活。这种方法不仅增强了团队成员之间的协作,还促进了组件在不同项目间的重用,显著加快了开发过程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2072099.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Python进阶(十)】——Matplotlib基础可视化

🍉CSDN小墨&晓末:https://blog.csdn.net/jd1813346972 个人介绍: 研一|统计学|干货分享          擅长Python、Matlab、R等主流编程软件          累计十余项国家级比赛奖项,参与研究经费10w、40w级横向 文…

Gradle安装使用

下载安装包 Gradle | Releases 解压后在.bash_profile添加环境变量 更新并检查 source ~/.bash_profile

计算机的错误计算(七十二)

摘要 讨论大数的余割函数 csc(x)的错误计算。 例1. 在 Excel 中计算 csc(1234567.89) . 直接贴图: 然而,正确值是 -0.2023325675399672e1(ISRealsoft 提供)。 Excel 的输出中有 6位错误数字。 例2. 在 Maple中计算 csc(32^58…

回归预测|基于北方苍鹰优化极端梯度提升树的数据回归预测Matlab程序NGO-XGBoost多特征输入单输出

回归预测|基于北方苍鹰优化极端梯度提升树的数据回归预测Matlab程序NGO-XGBoost多特征输入单输出 文章目录 前言回归预测|基于北方苍鹰优化极端梯度提升树的数据回归预测Matlab程序NGO-XGBoost多特征输入单输出 一、NGO-XGBoost模型1. 理解XGBoost2. 理解NGO优化算法3. NGO-XGB…

Kmeans算法原理及Python实现

K-means算法是一种广泛使用的聚类算法,其原理相对简单且易于实现,属于无监督学习的一种。以下是对K-means算法原理的详细解析: 一、基本思想 K-means算法的基本思想是将数据集划分为K个簇,使得每个簇内的数据点尽可能相似&#x…

从0到1使用webpack搭建react脚手架

背景 好多前端童鞋工作多年依然不会使用webpack搭建react脚手架,本文就介绍下如何从零开始搭建一个属于你自己的前端脚手架,提高自己的工程化实力,同时也提高团队的开发效率。 一、基础配置 目标:可以启动最简单的react项目 初…

调用股票网站接口读取大A数据——个股资金流入趋势

以某股票为例,调用自定义的一个类,读取数据。 class BigAData:# 获取资金流向数据def get_money_flow(self, stock_code, page1, num20, sortopendate, asc0):该函数通过股票代码从新浪财经API获取资金流向数据。参数包括股票代码、页数、每页数量、排序…

Elasticsearch安装 Kibana安装

安装Elasticsearch 一、拉取镜像或者上传 docker pull Elasticsearch 二、将上传的镜像导入(在仓库拉取的这一步跳过) docker load -i es.tar docker load -i 三、创建容器 1.Elasticsearch 注意修改到自己的网络(第八行) docker run -d \--nam…

创意无限,思维升级:2024年思维导图软件新趋势与精选推荐

如何高效地整理思绪、规划项目、乃至进行知识管理,成为了每个人都需要面对的重要课题。xmind思维导图这一强大的思维工具,可以辅助我们对只是进行梳理,这次我就展示一下这类思维导图工具有哪些。 1福晰思维导图 链接一下:https:…

HashMap 的实现原理

说一下 HashMap 的实现原理? JDK1.7 HashMap的主干是一个Entry数组。Entry是HashMap的基本组成单元,每一个Entry包含一个key-value键值对。(其实所谓Map其实就是保存了两个对象之间的映射关系的一种集合),其中Key 和…

pycharm 出现库已经安装了,但是无法导入的解决方法

打开File - Setttings , 找到 Project interpreter 找到system interpreter 安装

Golang | Leetcode Golang题解之第372题超级次方

题目: 题解: const mod 1337func pow(x, n int) int {res : 1for ; n > 0; n / 2 {if n&1 > 0 {res res * x % mod}x x * x % mod}return res }func superPow(a int, b []int) int {ans : 1for _, e : range b {ans pow(ans, 10) * pow(a…

【Python】家庭用电数据分析Prophet预测

数据集:Household Electricity Consumption | Kaggle 目录 数据集简介 探索性分析 Prophet预测 Prophet模型 Prophet理念 Prophet优点 数据集简介 240000-household-electricity-consumption-records数据集包含了一个家庭6个月的用电数据,收集于2…

vitepress打包异常 build error

今天给vitepress进行打包发布时出现了一个很奇怪的报错。 然后通过git版本回滚发现是正常发布的,说明环境是没有问题的 那么,就看看到改变了哪些文件。 环境版本 vitepress(^1.3.1) node(v18.19.0)猜测1 是文件的内容里面图片找不到导致的错误。猜测2 是…

Ps:首选项 - 历史记录

Ps菜单:编辑/首选项 Edit/Preferences 快捷键:Ctrl K Photoshop 首选项中的“历史记录” History选项卡允许用户更好地管理Photoshop中的编辑历史,确保在需要时能够回溯操作或提供详细的操作记录。 提示: 默认情况下,…

[数据集][目标检测]电力场景输电线防震锤检测数据集VOC+YOLO格式2721张2类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):2721 标注数量(xml文件个数):2721 标注数量(txt文件个数):2721 标注…

Go语言操作文件上传和下载应用教程

Go语言操作文件上传和下载应用教程 我们在使用Go的日常开发中,经常会遇到对文件的处理,例如:上传、下载、读写等(详情见Go 文件操作基本方法大全),且我们在实际应用中,基本都是使用框架自带的文…

数据结构(Java实现):链表习题

文章目录 1. 题目列表及链接2. 题目解析及代码2.1 删除链表中等于给定值 val 的所有节点2.2 反转一个单链表2.3 给定一个带有头结点 head 的非空单链表,返回链表的中间结点。如果有两个中间结点,则返回第二个中间结点2.4 输入一个链表,输出该…

Edge浏览器:Github加速插件,让你在国内自由自在的访问Github!

你是否有访问GitHub要么超级慢,要么无法访问的时刻,是不是感觉痛苦不已; 现在给大家分享我解决问题的方法。 点击浏览器右上角的三个点【…】按钮,然后选择【扩展】 选择【管理扩展】 点击【获取 Miscrosoft Edge扩展】 在搜索框…

解决方案:在jupyter notebook环境下安装不了numpy

文章目录 一、现象二、解决方案 一、现象 平台:autodl 镜像:PyTorch 2.0.0 Python 3.8(ubuntu20.04) Cuda 11.8 GPU:RTX 4090(24GB) * 1 CPU:12 vCPU Intel Xeon Platinum 8352V CPU 2.10GHz 内存:90GB 安装numpy环…