
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
!截图 2022-08-23 14-10-01
查看结果
现有多种向量搜索引擎,各有不同的功能集和效率表现。但如何衡量其性能?目前缺乏统一标准,且在特定场景下,用户可能关注某些方面而忽略其他。本项目提供一个通用框架,可在相同硬件约束下对不同引擎进行基准测试,帮助您选择最适合的解决方案。
运行任何基准测试需选择引擎、数据集并定义测试场景。特定场景可能包括服务器单机/分布式模式、不同客户端实现及客户端实例数量等配置。
./results/目录,便于分析比对适用于需要评估向量搜索引擎性能的开发者、研究人员及技术决策者,具体场景包括:
基准测试采用服务器-客户端模式,服务器运行在一台机器,客户端在另一台机器运行。
启动服务器
所有引擎通过Docker Compose部署,配置文件位于servers目录。
启动服务器实例的命令:
bashcd ./engine/servers/<engine-configuration-name> docker compose up
容器会暴露所有必要端口,供客户端连接。
运行客户端
安装依赖:
bashpip install poetry poetry install
运行基准测试:
bash$ poetry shell $ python run.py --help Usage: run.py [OPTIONS] 示例: python3 run.py --engines "qdrant-rps-m-*-ef-*" --datasets "dbpedia-openai-100K-1536-angular" # Qdrant RPS模式 python3 run.py --engines "*-m-*-ef-*" --datasets "glove-*" # 所有引擎及其配置用于glove数据集 Options: --engines TEXT [默认: *] --datasets TEXT [默认: *] --host TEXT [默认: localhost] --skip-upload / --no-skip-upload [默认: no-skip-upload] --install-completion 为当前shell安装补全功能。 --show-completion 显示当前shell的补全脚本,以便复制或自定义安装。 --help 显示帮助信息并退出。
命令支持为引擎和数据集指定通配符。基准测试结果存储在./results/目录中。
每个引擎都有配置文件,用于定义基准测试参数,配置文件位于configuration目录。
基准测试流程的每个步骤使用特定的配置路径:
connection_params - 客户端连接阶段使用的参数collection_params - 创建集合时使用的参数,通常包含索引参数upload_params - 上传数据到服务器时使用的参数search_params - 搜索阶段传递给客户端的参数,框架支持同一实验运行多种搜索配置参数的具体值因引擎而异。
数据集配置在datasets/datasets.json文件中。框架会自动下载数据集并存储在datasets目录。
可通过以下基类实现新引擎:
BaseConfigurator - 定义创建集合、设置索引参数的方法BaseUploader - 定义数据上传方法BaseSearcher - 定义数据搜索方法示例见clients目录。实现所有必要类后,需在ClientFactory中注册引擎。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务
以下是 qdrant/vector-db-benchmark 相关的常用 Docker 镜像,适用于 不同场景 等不同场景: