Spring AI 1.x 系列【59】容器化开发支持:Docker Compose 与 Testcontainers

1. 概述

在开发 Spring AI 应用时,经常需要连接各种外部服务 ------ 模型服务(如 Ollama)、向量数据库(如 ChromaQdrantWeaviateMilvusOpenSearch)、MCP 网关等。手动安装和配置这些服务既繁琐又容易出错。

Spring AI 提供了两种开箱即用的容器化解决方案,让开发者无需关心服务连接细节:

方案 适用阶段 原理
Docker Compose 本地开发 通过 Docker Compose 启动服务容器,Spring Boot 自动配置连接
Testcontainers 集成测试 通过 Testcontainers 在测试中动态启动容器,测试结束自动销毁

两者的共同优势:只需添加一个依赖,无需手动配置连接参数Spring AI 会通过服务连接工厂(Service Connection Factory)自动探测容器并建立连接。


2. Docker Compose 支持

2.1 依赖配置

Spring AI 提供了 Spring Boot 自动配置,用于连接通过 Docker Compose 运行的模型服务或向量数据库。

Mavenpom.xml):

xml 复制代码
<dependency>
   <groupId>org.springframework.ai</groupId>
   <artifactId>spring-ai-spring-boot-docker-compose</artifactId>
</dependency>

Gradlebuild.gradle):

groovy 复制代码
dependencies {
    implementation 'org.springframework.ai:spring-ai-spring-boot-docker-compose'
}

📖 请参阅 依赖管理 章节,将 Spring AI BOM 添加到你的构建文件中。

2.2 服务连接工厂

spring-ai-spring-boot-docker-compose 模块提供了以下服务连接工厂:

连接详情(Connection Details) 匹配容器镜像
AwsOpenSearchConnectionDetails localstack/localstack
ChromaConnectionDetails chromadb/chromaghcr.io/chroma-core/chroma
MongoConnectionDetails mongodb/mongodb-atlas-local
OllamaConnectionDetails ollama/ollama
OpenSearchConnectionDetails opensearchproject/opensearch
QdrantConnectionDetails qdrant/qdrant
TypesenseConnectionDetails typesense/typesense
WeaviateConnectionDetails semitechnologies/weaviatecr.weaviate.io/semitechnologies/weaviate
McpSseClientConnectionDetails docker/mcp-gateway

📖 Spring Bootspring-boot-docker-compose 模块提供了更多通用服务连接。完整列表请参阅 Docker Compose Support 文档。


3. Testcontainers 支持

3.1 依赖配置

Spring AI 提供了 Spring Boot 自动配置,用于连接通过 Testcontainers 运行的模型服务或向量数据库。

Mavenpom.xml):

xml 复制代码
<dependency>
   <groupId>org.springframework.ai</groupId>
   <artifactId>spring-ai-spring-boot-testcontainers</artifactId>
</dependency>

Gradlebuild.gradle):

groovy 复制代码
dependencies {
    implementation 'org.springframework.ai:spring-ai-spring-boot-testcontainers'
}

📖 请参阅 依赖管理 章节,将 Spring AI BOM 添加到你的构建文件中。

3.2 服务连接工厂

spring-ai-spring-boot-testcontainers 模块提供了以下服务连接工厂:

连接详情(Connection Details 匹配容器类型
AwsOpenSearchConnectionDetails LocalStackContainer
ChromaConnectionDetails ChromaDBContainer
McpSseClientConnectionDetails DockerMcpGatewayContainer
MilvusServiceClientConnectionDetails MilvusContainer
MongoConnectionDetails MongoDBAtlasLocalContainer
OllamaConnectionDetails OllamaContainer
OpenSearchConnectionDetails OpensearchContainer
QdrantConnectionDetails QdrantContainer
TypesenseConnectionDetails TypesenseContainer
WeaviateConnectionDetails WeaviateContainer

📖 Spring Bootspring-boot-testcontainers 模块提供了更多通用服务连接。完整列表请参阅 Testcontainers Service Connections 文档。


4. 总结

Spring AI 通过两个专用模块,将容器化服务连接的复杂度降到最低:

对比维度 Docker Compose Testcontainers
用途 本地开发环境 集成测试
生命周期 手动或通过 docker compose 管理 测试框架自动管理(启动/销毁)
服务类型 9AI 专用 + Spring Boot 通用 10AI 专用 + Spring Boot 通用
配置量 添加依赖即可 添加依赖即可

核心原则 :只需添加对应依赖,Spring Boot 自动配置会探测运行中的容器并建立连接,开发者无需手写任何连接参数。

相关推荐
阿里云大数据AI技术1 小时前
光轮智能 × 阿里云:共建 Physical AI 云上数据、评测与持续学习基础设施
人工智能·机器学习
机器之心1 小时前
实锤了:Claude Code偷查用户,时区、中国AI实验室全是关键词
人工智能·openai
网易云信1 小时前
Cursor点燃个人开发者,企业级AI为何频频受挫?Agent工厂从提效工具到AI员工的跃迁
人工智能·开源
网易云信1 小时前
解锁触手可及的温暖:网易智企 x Wander Puffs AI 云游泡芙
人工智能
转转技术团队1 小时前
从 PRD 到可验证代码:AI 需求开发闭环实践
人工智能
机器之心1 小时前
飞书让表格变成「AI同事」加入群聊,不打开表就能用表
人工智能·openai
Bigfish_coding2 小时前
前端转agent-【python】-15 AI Agent 可观测性入门:LangFuse 链路追踪、Token 监控与 LLM 质量评估
人工智能
我唔知啊2 小时前
我把 Claude Code 拆成了一间餐厅:从一句话到一次回复,中间到底发生了什么
人工智能
Harry技术2 小时前
02 · Codex 核心概念:代理、沙箱、审批和项目说明书
人工智能