KServe 中 Ray Serving 并行模型推理的 API 兼容性问题解析
在 KServe v0.12 版本中,用户在使用 Ray Serving 进行并行模型推理时遇到了一个关键的 API 兼容性问题。这个问题源于 Ray 框架自身的 API 演进,导致 KServe 原有的部署方式无法正常工作。
问题背景
Ray 是一个流行的分布式计算框架,KServe 利用它来实现高效的并行模型推理功能。在 KServe 的文档中,提供了一个使用 Ray Serving 进行并行推理的示例,这个功能对于需要高吞吐量推理服务的场景非常有用。
问题现象
当用户按照 KServe 文档中的示例代码进行操作时,服务启动失败并抛出错误信息,明确指出使用的 API 已被完全弃用。错误信息表明,Ray 2.8 及以上版本已经移除了原先的部署方式,要求开发者改用新的 serve.run() 方法。
技术分析
这个问题本质上是一个框架间的版本兼容性问题:
-
Ray 框架的演进:Ray 2.8 版本对 Serving API 进行了重大重构,移除了旧的部署方式,这是框架发展过程中的正常演进。
-
KServe 的依赖关系:KServe v0.12 版本依赖 Ray 2.9 及以上版本,这意味着它必须适应 Ray 的新 API。
-
影响范围:所有使用 KServe v0.12 并希望利用 Ray Serving 进行并行推理的用户都会遇到这个问题。
解决方案
KServe 开发团队已经意识到这个问题,并在主分支中进行了修复。具体修复内容包含在 PR #3556 中。这个修复确保了 KServe 能够与最新版本的 Ray 框架兼容。
对于用户来说,解决方案有以下几种:
-
升级到修复版本:KServe 已经发布了包含此修复的 v0.12.1 补丁版本,用户可以直接升级到这个版本。
-
临时解决方案:如果暂时无法升级,可以考虑降级 Ray 到 2.7 或更早版本,但这不推荐作为长期方案。
最佳实践建议
-
版本兼容性检查:在使用 KServe 或其他类似框架时,应该仔细检查各组件间的版本兼容性。
-
及时更新:关注框架的更新日志,特别是涉及 API 变更的内容。
-
测试环境验证:在生产环境部署前,先在测试环境中验证新版本的功能和兼容性。
总结
这个案例展示了开源生态系统中常见的版本兼容性挑战。KServe 团队快速响应并修复了这个问题,体现了开源社区的高效协作。对于用户来说,理解框架间的依赖关系并保持组件更新是避免类似问题的关键。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C063
MiniMax-M2.1从多语言软件开发自动化到复杂多步骤办公流程执行,MiniMax-M2.1 助力开发者构建下一代自主应用——全程保持完全透明、可控且易于获取。Python00
kylin-wayland-compositorkylin-wayland-compositor或kylin-wlcom(以下简称kywc)是一个基于wlroots编写的wayland合成器。 目前积极开发中,并作为默认显示服务器随openKylin系统发布。 该项目使用开源协议GPL-1.0-or-later,项目中来源于其他开源项目的文件或代码片段遵守原开源协议要求。C01
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
agent-studioopenJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力TSX0131
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00