Milvus 可观测性最佳实践

Milvus 介绍

Milvus 是一个开源的向量数据库,专为处理大规模、高维度向量数据而设计,广泛应用于人工智能、推荐系统、图像检索、自然语言处理等场景。它支持亿级向量的高效存储与快速检索,内置多种相似度搜索算法(如 HNSW、IVF、FLAT),并支持 GPU 加速,极大提升了检索性能。Milvus 提供易用的 API 接口,兼容多种数据格式,支持水平扩展,方便集成到各类 AI 应用中,是构建智能搜索系统的理想选择。

对 Milvus 进行可观测和监控是保障向量数据库稳定、高效运行的基础。通过实时监控系统资源使用、检索延迟、查询吞吐等关键性能指标,可以及时发现瓶颈、排查故障,确保向量检索任务的准确性与响应速度。同时,可观测性有助于预测容量需求、优化硬件资源配置,提升整体系统的可用性与弹性。它还支持自动化运维、问题追踪和性能调优,为构建智能应用提供稳定可靠的数据服务支撑。简而言之,完善的可观测体系是实现 Milvus 高性能、高可用及可扩展性的关键保障。

观测云

观测云是一款专为 IT 工程师打造的全链路可观测产品,它集成了基础设施监控、应用程序性能监控和日志管理,为整个技术栈提供实时可观察性。这款产品能够帮助工程师全面了解端到端的用户体验追踪,了解应用内函数的每一次调用,以及全面监控云时代的基础设施。此外,观测云还具备快速发现系统安全风险的能力,为数字化时代提供安全保障。

本实践 Milvus 组件主要部署在 K8s 环境,并通过观测云进行数据采集、分析和监控。

部署 DataKit

DataKit 是一个开源的、跨平台的数据收集和监控工具,由观测云开发并维护。它旨在帮助用户收集、处理和分析各种数据源,如日志、指标和事件,以便进行有效的监控和故障排查。DataKit 支持多种数据输入和输出格式,可以轻松集成到现有的监控系统中。

登录观测云控制台,在「集成」 - 「DataKit」选择对应安装方式。下载 datakit.yaml,拷贝第 3 步中 ENV_DATAWAY 键的值。

编辑 datakit.yaml,修改 DaemonSet 环境变量:

  • 修改 ENV_DATAWAY 的值为上一步中拷贝的值;
  • 修改 ENV_CLUSTER_NAME_K8S 的值为集群名称;
  • 新增 ENV_NAMESPACE,值为集群名称;

执行以下命令部署 DataKit 并验证:

arduino 复制代码
kubectl apply -f datakit.yaml
kubectl get pods -n datakit

采集器配置

前置条件

  • 已经安装好 Milvus,本文测试的是 Helm 安装的 Milvus(v2.4.x),安装方式可参考:
    milvus.io/docs/zh/v2....
  • 检查 value.yaml 中的指标暴露是否已经打开(默认是开启的)
  • 检查 service.yaml 中对应指标暴露的端口是否是 9091
  • 以上操作完成后可以进入 milvus 集群中某一个容器,通过 curl http://localhost:9091/metrics 命令检查是否有指标数据

配置采集器

  • 开启 Kubernetes Prometheus Discovery 插件

创建 Configmap 并挂载为 DataKit kubernetesprometheus 采集器的配置文件即可开启采集,插件通过角色、命名空间、标签自动发现采集端点。注意在 [inputs.kubernetesprometheus.instances.custom.tags] 中配置 Kubernetes 集群名作为指标标签,其他标签将根据配置自动取值。标签用于区分不同集群、实例、关联基础设施指标。插件配置举例如下:

ini 复制代码
apiVersion: v1
kind: ConfigMap
metadata:
  name: datakit-conf
  namespace: datakit
data:
  kubernetesprometheus.conf: |-
    [inputs.kubernetesprometheus]
        node_local = true
        [[inputs.kubernetesprometheus.instances]]
            role            = "pod"
            # milvus-cluster of namespace
            namespaces      = ["milvus-cluster"]
            selector        = "app.kubernetes.io/name=milvus"
            scrape          = "true"
            scheme          = "http"
            port            = "9091"
            path            = "/metrics"
            # 采集器采集频率
            scrape_interval = "60s" 
            [inputs.kubernetesprometheus.instances.custom]
                measurement        = "milvus"
                job_as_measurement = false
                [inputs.kubernetesprometheus.instances.custom.tags]
                    cluster_name_k8s = "k8s_saas"
                    instance         = "__kubernetes_mate_instance"
                    pod_name         = "__kubernetes_pod_name"
                    pod_namespace    = "__kubernetes_pod_namespace"
                    node_name        = "__kubernetes_pod_node_name"

为 DataKit 挂载配置文件的方式如下:

yaml 复制代码
        - mountPath: /usr/local/datakit/conf.d/kubernetesprometheus/kubernetesprometheus.conf
          name: datakit-conf
          subPath: kubernetesprometheus.conf
          readOnly: true

关键指标

Proxy

指标 指标说明
milvus_proxy_search_vectors_count 累计查询的向量数。
milvus_proxy_insert_vectors_count 插入向量的累计数量。
milvus_proxy_sq_latency 搜索和查询请求的延迟。
milvus_proxy_mutation_latency 突变请求的延迟。
milvus_proxy_req_count 所有类型接收请求的数量。
milvus_proxy_cache_hit_count 每次缓存读取操作的命中和失败率的统计。

Query Node

指标 指标说明
milvus_querynode_sq_req_count 搜索和查询请求的累计数量。
milvus_querynode_sq_req_latency 查询节点的查询请求延迟。
milvus_querynode_entity_num 每个查询节点上可查询和可搜索的实体数量。
milvus_querynode_segment_num 每个查询节点加载的 segment 数量。

Data Node

指标 指标说明
milvus_datanode_msg_rows_count 数据节点消费的流消息的行数。目前数据节点统计的流消息仅包括插入和删除消息。
milvus_datanode_flushed_data_size 每个刷写消息的大小。目前数据节点统计的流消息仅包括插入和删除消息。
milvus_datanode_unflushed_segment_num 每个数据节点上创建的未刷写 segment 的数量。
milvus_datanode_compaction_latency 每个数据节点执行合并任务所花费的时间。

Query Coord

指标 指标说明
milvus_querycoord_collection_num 当前被 Milvus 加载的集合数量。

Root Coord

指标 指标说明
milvus_rootcoord_ddl_req_count 包括 CreateCollection、DescribeCollection 等在内的所有 DDL 请求的总数。
milvus_rootcoord_ddl_req_latency 所有类型 DDL 请求的延迟。
milvus_rootcoord_id_alloc_count root coord 分配的 ID 的累计数量。

Index Node

指标 指标说明
milvus_indexnode_build_index_latency 用于构建索引的时间。

场景视图

登录观测云控制台,点击「场景」 -「新建仪表板」,输入 "Milvus", 选择 "Milvus K8S 监控视图",点击 "确定" 即可添加视图。

监控器(告警)

观测云内置了监控器模板,可以选择从模版创建监控器,并开启适合业务的监控器以及时通知相关成员关注问题,触发条件、频率等信息可以依据实际业务进行调整。

登录观测云控制台,点击「监控」 -「新建监控器」,输入 "Milvus", 选择对应的监控器,点击 "确定" 即可添加。

监控器名称 告警提示
Milvus 实例{{instance}} 缓存命中过低 用于监控Milvus缓存机制的命中效率,有助于分析性能优化空间
Milvus 实例{{instance}} 查询延迟时间过长 用于监控搜索请求的整体响应开销,帮助定位性能瓶颈
Milvus 实例{{instance}} 突变发送延迟过高 用于监控写请求的发送延迟,判断写路径是否存在拥塞或异常
Milvus 实例{{instance}} 请求延迟过高 用于监控延迟是否集中或存在长尾问题

总结

Milvus 作为一款专为大规模、高维度向量数据设计的开源向量数据库,通过观测云平台统一采集并监控其关键性能指标,对于保障系统高性能、高可用及弹性扩展至关重要。实时监控检索延迟、查询吞吐、缓存命中率、内存与 CPU 使用率等核心指标,能够全面洞察向量检索行为与资源负载。这些数据的持续追踪不仅帮助优化索引与缓存策略、提升检索效率,还能精准识别性能瓶颈,实现故障的提前预警与分钟级根因定位,确保 AI 应用在亿级向量场景下依旧稳定、可靠、高效运行。

相关推荐
岚天start1 天前
Linux系统网络排查工具总结
linux·运维·网络·监控·扫描·连通性·流量
可观测性用观测云2 天前
Ceph 可观测性最佳实践
监控
云游3 天前
大模型性能指标的监控系统(prometheus3.5.0)和可视化工具(grafana12.1.0)基础篇
grafana·prometheus·可视化·监控
海风极客4 天前
一个案例带你搞懂Prometheus指标类型(下)
监控
可观测性用观测云5 天前
OpenTelemetry WebSocket 监控终极方案:打通最后一公里
监控
可观测性用观测云7 天前
观测云接收 OpenTelemetry Collector 数据最佳实践
监控
SRETALK8 天前
夜莺开源监控,模板函数一览
运维·监控·自动化运维
可观测性用观测云12 天前
使用观测云打造企业级监控告警中心
监控