OME项目在Kubernetes集群中的安装指南
2025-06-29 12:54:17作者:农烁颖Land
项目概述
OME是一个基于Kubernetes的模型服务框架,支持多种部署模式,为AI模型推理服务提供灵活高效的运行环境。本文将详细介绍如何在Kubernetes集群中安装和配置OME项目。
前置准备
在开始安装OME之前,需要确保您的Kubernetes集群满足以下要求:
- Kubernetes版本:至少需要1.27.1或更高版本
- kubectl工具:已配置并能与集群通信
- 部署模式选择:
- RawDeployment模式:支持基于自定义指标的扩展(需要KEDA和Prometheus)
- Serverless模式:需要Knative Serving和Istio
- MultiNodeRayVLLM模式:需要Ray集群支持
依赖组件安装
1. Istio安装(Serverless模式必需)
版本要求:至少1.19版本
安装完成后,需要创建IngressClass资源:
apiVersion: networking.k8s.io/v1
kind: IngressClass
metadata:
name: istio
spec:
controller: istio.io/ingress-controller
注意:如果使用云服务商托管的Kubernetes,可以考虑使用其提供的托管Istio服务。
2. Cert Manager安装
版本要求:至少1.9.0版本
Cert Manager用于生产级安装中的webhook证书管理。对于测试环境,也可以使用自签名证书。
3. Knative Serving安装(Serverless模式必需)
安装时需要注意:
- 如需使用PodSpec字段(如nodeSelector、affinity等),需要开启相应的功能标志
- 如果使用私有镜像仓库,需要配置Knative跳过镜像摘要解析:
kubectl -n knative-serving edit configmap config-deployment
添加以下内容到data部分:
data:
registriesSkippingTagResolving: ko.local, dev.local, ghcr.io
4. KEDA安装(RawDeployment模式必需)
推荐使用Helm进行安装,用于支持基于自定义指标的自动扩展。
5. Prometheus安装(RawDeployment模式必需)
安装步骤:
- 添加Helm仓库并更新
- 安装kube-prometheus-stack
OME项目安装
获取项目代码
项目代码需要放置在GOPATH的特定目录下:
mkdir -p ${GOPATH}/src/github.com/sgl-project
cd ${GOPATH}/src/github.com/sgl-project
git clone <项目仓库地址>
cd ome
安装最新开发版本
执行以下命令安装OME:
make install
控制器将运行在ome命名空间中。
卸载OME
如需卸载,执行以下命令:
make uninstall
部署模式说明
-
RawDeployment模式:
- 优点:支持挂载多个卷,突破Knative限制
- 限制:不支持缩容到零和从零扩展
-
Serverless模式:
- 优点:基于请求量的自动扩展,支持缩容到零和从零扩展
- 特性:支持版本管理和基于版本的灰度发布
-
MultiNodeRayVLLM模式:
- 特点:支持多节点Ray集群和VLLM模型服务
- 限制:不支持自动扩展和灰度部署
常见问题处理
- 版本兼容性问题:确保各组件版本符合最低要求
- 私有镜像仓库配置:正确配置Knative以跳过镜像摘要解析
- 功能标志启用:如需使用高级PodSpec功能,确保开启相应功能标志
通过以上步骤,您可以在Kubernetes集群中成功安装和配置OME项目,根据实际需求选择合适的部署模式运行AI模型推理服务。
登录后查看全文
热门项目推荐
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0123
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
491
3.62 K
Ascend Extension for PyTorch
Python
300
332
暂无简介
Dart
740
178
React Native鸿蒙化仓库
JavaScript
297
346
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
866
473
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
289
123
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
11
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
65
20
仓颉编程语言测试用例。
Cangjie
43
870