GUI都流行四十年了!数据库操作怎么还和DOS系统一样难搞?

今天在讲Milvus的Attu之前,我们先来唠一段计算机行业的八卦。
不知道有多少人见识过早年的DOS系统?那是一个必须靠敲代码、输命令才能完成开机、建文件的时代,“会开电脑就已经很厉害了”,在那时候,还不是骂人的话
雷布斯在内,中国的第一代互联网精英们,都是这个时代的受益者。但很快,随着Windows的图形界面出现,它把复杂指令变成了点图标、拖窗口这样的简单操作,电脑的普及率也随之大幅提升。
当然,很多人对这个故事可能也不太熟,因为已经是40年前的事情了。
但很难相信,PC行业四十年前就完成的事情,在数据库行业,还是进行时状态。直到今天,操作很多数据库,想查一条数据、建一个数据集合,我们都得写专门Python/Go脚本;甚至只是切换不同环境的数据库,都要手动改配置。
开发做这些自然轻车熟路,但对RAG、推荐系统等场景的业务人员来说,门槛不低。
这也是今天为什么介绍Milvus的Web管理工具Attu的原因(尽管已经推出两三年了),但这绝对是我用过最好用的可视化界面替代命令行的数据库产品!
01 Attu是什么?
Attu是Milvus的全功能Web管理界面,就像MySQL有了Workbench、Redis有了RedisInsight,让你用浏览器就能完成所有数据库操作。
Attu采用前后端分离架构:React前端提供可视化操作界面,Node.js中间层封装Milvus SDK并暴露RESTful API,底层直连Milvus完成数据操作。简单说就是给Milvus套了个Web壳,把命令行操作变成图形界面点击。技术栈选型上,React负责UI交互,Express.js处理WebSocket实时推送,底层通过官方Node.js SDK与Milvus 2.x通信。
02 Attu解决什么痛点?
痛点1:管理数据对象要写代码 查看集群有哪些Collection、Partition、Database,或者创建、修改、删除这些对象,都需要写Python/Go脚本调用SDK。Attu提供Web界面,点击就能完成所有管理操作。
痛点2:向量数据看不懂 查询返回的768维向量是一串浮点数,无法直观判断数据内容。Attu自动显示向量维度和关联的标量字段,让数据可读。
痛点3:验证查询效果慢 测试RAG召回效果需要写脚本执行Search,每次修改参数都要重新运行代码。Attu提供Search界面,输入查询条件立即返回结果,实时查看召回内容和相似度分数。
痛点4:多环境切换麻烦 开发、测试、生产环境的Milvus地址不同,每次切换需要修改代码配置。Attu支持保存多个连接配置,一键切换不同环境。
03 Attu完整功能实操指南
Attu 支持连接Milvus Standalone和Zilliz Cloud,可灵活使用本地或云托管数据库。本文采用Standalone部署方式进行实操。
环境准备 Docker 20.10+ Docker Compose 2.0+
前提条件:
部署standalone模式Milvus
wget https://raw.githubusercontent.com/milvus-io/milvus/refs/tags/v2.6.3/deployments/docker/standalone/docker-compose.yml
docker-compose up -d
docker-compose ps -a
1.开始部署Attu
方式一:Docker一键启动(推荐)
bash
docker run -d \
--name attu \
-p 8000:3000 \
-e MILVUS_URL=http://host.docker.internal:19530 \
zilliz/attu:2.6.1
# 访问 http://localhost:8000
方式二:Kubernetes中运行
kubectl apply -f https://raw.githubusercontent.com/zilliztech/attu/main/attu-k8s-deploy.yaml
访问主页面并登录
访问
http://localhost:8000,进入登录页面填写连接信息:
- Milvus Address:
localhost:19530(Docker用户填host.docker.internal:19530)
- Milvus Address:
点击"连接"按钮
640.webp
效果说明:
连接成功后自动跳转到Database列表页
默认显示
default数据库左侧导航栏展示所有Collection
640-1.webp
640-2.webp
2.数据库、集合和分区管理
这是Attu最核心的功能,相当于MySQL Workbench的表管理模块。
2.1 创建Database(Milvus 2.4+支持)
使用场景:
多租户隔离:不同业务线使用独立Database
环境分离:开发/测试/生产环境数据分离
点击左上角“+”号,输入数据库名称(如:knowledge_base_db)后创建
640-3.webp
640-4.webp
2.2创建Collection(核心功能)
Collection 是向量数据库中存储数据的基本单位,类似于关系型数据库中的表。
配置基本信息(新手建议):
Collection名称: product_vectors
描述: 商品向量搜索集合
# 字段配置
主键字段:
-名称: id
- 类型: VARCHAR
- Max Length: 64
- 自动ID: 否
向量字段:
- 名称: vector
- 类型: Float Vector
- 维度: 768
# Functions
BM25: 不启用
TextEmbedding: 不启用
# Settings
一致性级别: Bounded
分片数量: 1
启用动态 Schema: ✅ 是
创建后加载: ✅ 是
640-5.webp
640-6.webp
2.3 Schema定义
这是 product_vectors 集合的数据模型定义界面,展示了集合的核心结构:
字段定义
id:主键字段,VarChar(1024) 类型,配置了自动索引
vector:向量字段,FloatVector(768) 维度,使用 COSINE 余弦相似度索引
$meta:动态字段,JSON 类型,支持灵活的元数据存储,可创建 JSON 索引
640-7.webp
左侧包含了集合的状态信息
640-8.webp
2.4数据插入(Import Data)
数据:浏览和管理collection中存储的具体数据记录
进入Collection详情页数据标签,可导入文件。这里采用示例数据导入
640-9.webp
640-10.webp
640-11.webp
2.5向量搜索配置
这是 向量相似度搜索 的查询配置界面,用于执行向量检索操作:
2.5.1查询参数设置
vector 字段:选择要搜索的向量字段(FloatVector(768),COSINE 索引)
搜索数量:返回前 15 个最相似的结果
一致性级别:Bounded(有界一致性)
输出字段:2 个字段(可指定返回哪些字段)
分区选择:_default 分区
640-12.webp
2.5.2如何查询?
1.选择数据标签里面找到已有数据的vector进行复制
640-13.webp
2.输入vector点击搜索按钮进行查询
说明:参考2.5.1查询参数进行自定义查询
640-14.webp
3.查看数据(支持查看图片)
640-15.webp
4.删除数据
说明:选中并删除一条数据
640-16.webp
说明:清空整个collection数据(须谨慎)
640-17.webp
5.修改数据
说明:支持upsert
640-18.webp
640-19.webp
2.6分区(Partition)管理
分区是 Collection 内部的逻辑隔离单元,用于将数据按业务需求分组存储:
隔离存储:不同分区的数据物理隔离,互不影响
精准查询:搜索时可指定分区,大幅提升效率(避免全表扫描)
灵活管理:可独立加载/释放分区,节省内存资源
典型场景:按时间分区(如按月)、按类别分区(如商品类目)、按租户分区(多租户隔离)
640-20.webp
3.Play功能
Play(beta) 是Attu提供的一个API测试平台,让你可以直接在网页上测试Milvus的各种操作,而不需要编写完整的程序代码。
640-21.webp
4.Milvus运维管理界面
这是系统健康监控仪表板,让管理员可以实时查看Milvus集群的运行状态。
界面顶部展示了Milvus系统的核心信息。当前系统运行在STANDALONE单机模式下,使用的是2.6.3版本。除了版本号外,系统还详细记录了代码的Git提交版本号、Go语言运行环境信息,以及系统的构建时间和部署创建时间,这些时间戳帮助管理员追溯系统的部署历史。
640-22.webp
下方页签停留在Milvus节点标签,该页面用于查看所有服务组件的运行状态。往下依次是Milvus配置和环境变量标签,分别用于查看系统的配置参数和环境设置。慢请求标签则专门用于监控那些响应缓慢的查询操作,帮助定位性能瓶颈。再往下的Segment和副本标签,分别管理数据段信息和数据副本的分布情况。最后是资源组标签,用于查看集群的资源分配状况。这些功能模块共同构成了Milvus的相对完整运维监控体系。
640-23.webp
5.任务管理界面
Milvus 节点的任务管理页面,包含五种任务类型:QueryCoord 任务、压缩(Compaction)任务、索引构建任务、Import 任务和 Sync 任务。界面以表格形式展示任务信息,包含任务名称、Collection 名称、Collection ID、任务类型、任务状态和操作等字段。
24.png
25.webp
6.RBAC 权限管理界面
用户和角色管理页面,采用 RBAC(基于角色的访问控制)模型。界面分为用户、角色、权限组三个标签页。用户管理模块提供添加用户、修改密码、编辑角色、删除等功能。表格展示用户与角色的对应关系,示例中root 用户被分配了 admin 角色。
640-26.webp
创建步骤:
前提条件:
必须要以root用户重新登录attu,默认密码Milvus。
第一步:创建角色
在角色标签页点击+ 角色按钮,创建自定义角色
角色名:analyst_role(分析师角色)
授予权限:Query、Search(只读权限)
Collection 模块:用于细粒度控制特定 Collection 的操作权限
数据库模块:用于控制整个数据库级别的权限
集群模块:用于控制集群级别的全局权限
27.png
28.webp
第二步:创建用户并绑定刚才的角色
在用户标签页点击+ 用户按钮,创建用户:
29.webp
30.webp
04 写在最后
Attu可以解决大部分的日常管理场景,它能让你从写脚本操作解放出来,把时间花在更有价值的事情上——比如优化RAG的召回策略,设计agent架构。
最重要的是,时间可以用在技术开发上,而不是每天8小时工作时间,还要专门抽一小时帮业务干数据查看、管理、写脚本这样的无意义活动,这真的很重要!!!

技术干货
可处理十亿级向量数据!Zilliz Cloud GA 版本正式发布
本次 Zilliz Cloud 大版本更新提升了 Zilliz Cloud 向量数据库的可用性、安全性和性能,并推出了一系列新功能。这次升级后,Zilliz Cloud 能够更好地为用户提供面向各种应用场景的向量数据库服务,不断提升用户体验。
2023-4-7
技术干货
门槛一降再降,易用性大幅提升!Milvus 2.2.12 持续升级中
一句话总结 Milvus 2.2.12 :低门槛、高可用、强性能。
2023-7-27
技术干货
LLM 快人一步的秘籍 —— Zilliz Cloud,热门功能详解来啦!
此次我们在进行版本更新的同时,也增加了多项新功能。其中,数据迁移(Migration from Milvus)、数据的备份和恢复(Backup and Restore)得到了很多用户的关注。本文将从操作和设计思路的层面出发,带你逐一拆解 Zilliz Cloud 的【热门功能】。
2023-4-10




