Ubuntu下使用Docker部署Milvus及可视化工具实战指南
1. 环境准备与Docker安装在开始部署Milvus之前我们需要确保Ubuntu系统已经准备好基础环境。我建议使用Ubuntu 18.04或20.04 LTS版本这些版本经过长期支持稳定性更有保障。实测在Ubuntu 22.04上也能正常运行但可能会遇到一些依赖库版本冲突的问题。首先更新系统软件包是个好习惯sudo apt update sudo apt upgrade -y安装Docker的官方推荐方式是通过官方脚本这样能确保获取最新稳定版本。我遇到过直接用apt安装的版本过旧导致兼容性问题的情况。执行以下命令curl -fsSL https://get.docker.com | sudo sh安装完成后记得将当前用户加入docker组避免每次都要sudosudo usermod -aG docker $USER newgrp docker验证Docker是否安装成功docker --version正常应该显示类似Docker version 20.10.17的版本信息。注意如果公司内网有代理限制可能需要联系IT部门配置Docker的代理设置。我在企业环境中部署时就遇到过因为网络限制导致镜像拉取失败的情况。2. 部署Milvus数据库2.1 拉取Milvus镜像Milvus提供了CPU和GPU两个版本的镜像。对于大多数应用场景CPU版本就足够了。我建议使用2.x版本因为1.x版本已经停止维护。执行以下命令拉取镜像docker pull milvusdb/milvus:v2.2.3如果想使用GPU加速需要NVIDIA显卡和驱动支持docker pull milvusdb/milvus:v2.2.3-gpu2.2 准备配置文件和数据目录Milvus运行需要三个关键目录conf存放配置文件db存放向量数据logs存放运行日志我习惯把这些目录放在/data/milvus下方便管理mkdir -p /data/milvus/{conf,db,logs}获取默认配置文件wget https://raw.githubusercontent.com/milvus-io/milvus/v2.2.3/configs/milvus.yaml -O /data/milvus/conf/milvus.yaml2.3 启动Milvus容器这是最关键的一步需要正确配置端口映射和目录挂载。我整理了一个最常用的启动命令docker run -d --name milvus \ -p 19530:19530 \ -p 9091:9091 \ -v /data/milvus/conf:/var/lib/milvus/conf \ -v /data/milvus/db:/var/lib/milvus/db \ -v /data/milvus/logs:/var/lib/milvus/logs \ milvusdb/milvus:v2.2.3参数说明19530客户端连接端口必须映射9091监控指标端口可选三个-v参数分别挂载配置、数据和日志目录提示如果修改了配置文件需要重启容器才能生效。我建议第一次启动时使用默认配置等系统运行起来后再根据需求调整。3. 部署Milvus可视化工具3.1 安装Milvus-EMMilvus官方提供了一个名为Milvus-EM的可视化管理工具可以直观地查看集合、索引和向量数据。拉取镜像docker pull milvusdb/milvus-em:v0.6.0启动容器docker run -d --name milvus-em \ -p 3000:3000 \ -e MILVUS_URLhttp://宿主机IP:19530 \ milvusdb/milvus-em:v0.6.0注意这里的宿主机IP需要替换为实际IP地址。如果Milvus和EM部署在同一台机器可以使用hostname -I查看IP。3.2 访问可视化界面启动完成后在浏览器访问http://宿主机IP:3000首次打开会要求输入Milvus服务地址格式为http://宿主机IP:19530。连接成功后就能看到类似这样的界面![可视化界面示意图]在界面上可以查看所有集合(Collection)和分区(Partition)检查向量索引状态执行简单的查询操作监控系统性能指标4. 常见问题排查4.1 容器启动失败如果Milvus容器启动后立即退出可以查看日志定位问题docker logs milvus常见错误包括端口冲突检查19530端口是否被占用权限问题确保挂载目录有读写权限配置错误检查milvus.yaml格式是否正确4.2 可视化工具无法连接如果Milvus-EM无法连接到Milvus服务检查防火墙是否放行了19530端口MILVUS_URL环境变量设置是否正确Milvus服务是否正常运行docker exec -it milvus milvus status4.3 性能优化建议根据我的经验生产环境部署时建议为db目录挂载SSD存储调整配置文件中的缓存大小根据数据量选择合适的索引类型定期清理不需要的日志文件5. 进阶配置5.1 使用docker-compose部署对于更复杂的部署场景我推荐使用docker-compose。创建一个docker-compose.yml文件version: 3.5 services: milvus: image: milvusdb/milvus:v2.2.3 ports: - 19530:19530 - 9091:9091 volumes: - /data/milvus/conf:/var/lib/milvus/conf - /data/milvus/db:/var/lib/milvus/db - /data/milvus/logs:/var/lib/milvus/logs environment: - TZAsia/Shanghai restart: always milvus-em: image: milvusdb/milvus-em:v0.6.0 ports: - 3000:3000 environment: - MILVUS_URLhttp://milvus:19530 depends_on: - milvus restart: always然后运行docker-compose up -d这种方式可以更好地管理多个容器的依赖关系。5.2 配置持久化与备份为了保证数据安全建议定期备份/data/milvus/db目录配置日志轮转避免日志文件过大使用NFS或云存储作为持久化卷我在实际项目中遇到过磁盘写满导致服务崩溃的情况后来设置了监控告警才解决这个问题。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2439396.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!