milvus安装

docker代理设置:


cd /etc/docker/daemon.json

添加代理:"https://docker.anyhub.us.kg/"

启动etcd、minio、milvus


由于milvus依赖etcd和minio,因此需要先启动这2个组件。同样也使用docker进行启动。
etcd:用来存储milvus的元数据。
minio:用来存储milvus的向量数据和索引数据。
下载milvus-standalone-docker-compose.yml 文件,保存为docker-compose.yml:

手动创建docker-compose.yml文件

version: '3.5'
services:
  etcd:
    container_name: milvus-etcd
    image: quay.io/coreos/etcd:v3.5.5
    environment:
      - ETCD_AUTO_COMPACTION_MODE=revision
      - ETCD_AUTO_COMPACTION_RETENTION=1000
      - ETCD_QUOTA_BACKEND_BYTES=4294967296
      - ETCD_SNAPSHOT_COUNT=50000
    volumes:
      - ${DOCKER_VOLUME_DIRECTORY:-.}/volumes/etcd:/etcd
    ports:
      - "2379:2379"
    command: etcd -advertise-client-urls=http://127.0.0.1:2379 -listen-client-urls http://0.0.0.0:2379 --data-dir /etcd
    healthcheck:
      test: ["CMD", "etcdctl", "endpoint", "health"]
      interval: 5s
      timeout: 3s
      retries: 10

  minio:
    container_name: milvus-minio
    image: minio/minio:RELEASE.2023-03-20T20-16-18Z
    environment:
      MINIO_ACCESS_KEY: minioadmin
      MINIO_SECRET_KEY: minioadmin
    ports:
      - "9001:9001"
      - "9000:9000"
    volumes:
      - ${DOCKER_VOLUME_DIRECTORY:-.}/volumes/minio:/minio_data
    command: minio server /minio_data --console-address ":9001"
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
      interval: 5s
      timeout: 3s
      retries: 10

  standalone:
    container_name: milvus-standalone
    image: milvusdb/milvus:v2.3.12
    command: ["milvus", "run", "standalone"]
    security_opt:
      - seccomp:unconfined
    environment:
      ETCD_ENDPOINTS: etcd:2379
      MINIO_ADDRESS: minio:9000
    volumes:
      - ${DOCKER_VOLUME_DIRECTORY:-.}/volumes/milvus:/var/lib/milvus
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:9091/healthz"]
      interval: 30s
      start_period: 90s
      timeout: 20s
      retries: 3
    ports:
      - "19530:19530"
      - "9091:9091"
    depends_on:
      - "etcd"
      - "minio"

networks:
  default:
    name: milvus

 镜像拉取:

docker pull quay.io/coreos/etcd:v3.5.5
docker pull minio/minio:RELEASE.2023-03-20T20-16-18Z
docker pull milvusdb/milvus:v2.3.12

 拉取完成:

 后台启动:

docker-compose up -d

查看启动状态:

docker-compose ps

docker-compose的其他命令:

docker-compose ps 查看容器
docker-compose stop 停止容器
docker-compose start 启动容器
docker-compose down 停止并删除容器(特别注意以免误删容器)

查看milvus日志:docker logs -f milvus-standalone

启动attu

attu为milvus的一款图形化管理工具,非常方便对milvus的一些管理。

attu镜像拉取:docker pull zilliz/attu:v2.3.9

docker run -d \
--name=attu \
-p 8000:3000 \
-e MILVUS_URL=192.168.230.71:19530 \
zilliz/attu:v2.3.9

需要开放端口:8000,19530

web访问地址:http://ip:8000/

到这里我们就完成了整个standalone的安装部署过程。
我们还可以访问minio对象存储的管理界面,查看milvus存储内容。

minio访问:

需要开放端口 9001

http://ip:9001

默认用户名和密码在docker-compose文件里面

### Milvus 安装指南 Milvus 提供了多种安装方式,适用于不同的场景和需求。以下是几种常见的安装方法及其适用范围: #### 1. 使用 Helm 安装 Milvus Operator 对于希望在 Kubernetes 集群中部署和管理 Milvus 的用户,可以使用 Milvus Operator 来简化这一过程。通过 Helm 安装 Milvus Operator 能够显著降低复杂度并提高效率[^1]。 ```bash helm repo add milvus https://zilliz.com/helm-charts helm install my-milvus milvus/milvus --version {chart-version} ``` 以上命令会将指定版本的 Milvus 部署到 Kubernetes 集群中。 --- #### 2. Docker 单机版安装 如果目标是在单台机器上快速启动 Milvus,则可以通过 Docker 运行官方镜像来实现。这种方法适合测试环境或小型应用。 ```bash docker pull milvusdb/milvus:v{version} # 替换为所需版本号 docker run -d --name milvus_cpu -p 19530:19530 -p 8080:8080 \ -v /path/to/data:/var/lib/milvus milvusdb/milvus:v{version} ``` 此方法简单快捷,无需额外配置即可完成基本功能验证[^4]。 --- #### 3. Milvus Lite (Python 库) 针对资源受限的设备或者需要快速原型设计的情况,可以选择 Milvus Lite。这是一种轻量化的 Python 库形式,可以直接嵌入到应用程序中而不需要单独的服务进程[^3]。 ```python from pymilvus import connections, FieldSchema, CollectionSchema, DataType, Collection connections.connect("default", host="localhost", port="19530") fields = [ FieldSchema(name="id", dtype=DataType.INT64, is_primary=True), FieldSchema(name="embedding", dtype=DataType.FLOAT_VECTOR, dim=128) ] schema = CollectionSchema(fields, "example_collection") collection = Collection(name="example", schema=schema) print(f"Collection created successfully: {collection.name}") ``` 注意:尽管 Milvus Lite 功能强大,但它仅限于本地运行且不支持分布式扩展[^3]。 --- #### 4. 源码编译安装 当需要自定义修改源代码或探索最新特性时,可以从 GitHub 上克隆仓库并通过源码构建 Milvus。这通常涉及 Go、C++ 和 Python 环境的搭建以及依赖项解决[^5]。 ```bash git clone https://github.com/milvus-io/milvus.git cd milvus make build ./build/scripts/run_server.sh ``` 这种方式较为复杂,建议具备一定开发经验后再尝试。 --- ### 总结 根据实际需求选择合适的安装方案非常重要。Kubernetes 用户推荐采用 **Helm Chart**;追求便捷性的开发者可选用 **Docker 单机版** 或者直接集成 **Milvus Lite** 到项目里;而对于高级定制化则需考虑基于源码的方式进行二次开发[^1][^3].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值