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 自动配置会探测运行中的容器并建立连接,开发者无需手写任何连接参数。

相关推荐
weixin_307779131 小时前
智能模拟数据生成平台:生成式AI合成数据技术重塑开发测试效能
人工智能·测试工具·算法·测试用例
掘金一周1 小时前
走过路过有没有好心人help一下,我有两个问题需要大家帮忙集思广益下 | 沸点周刊 6.11
人工智能·ai编程·沸点
cui17875681 小时前
物业费收缴困局的破题之路:2026年社区商业逻辑的底层重构
大数据·数据库·人工智能
北塔软件1 小时前
北塔软件智能体平台 | 不只监控,更是AI时代的数据资产
运维·人工智能·知识库·北塔软件
早起CaiCai1 小时前
【Pytorch 实践1】手写数字
人工智能·pytorch·python
monsion1 小时前
Loop Engineering:你不再 prompt agent,而是设计 prompt agent 的系统
大数据·人工智能·prompt
Plastic garden1 小时前
K8s(10)NFS 的动态 PV 创建数据库给k8s的mysql和redis
docker·容器·kubernetes
卡梅德生物科技小能手1 小时前
卡梅德生物科普MCAM(黑色素瘤细胞黏附分子)
人工智能·经验分享·深度学习
Flittly1 小时前
【AgentScope Java新手村系列】(2)第一个Agent-基础对话
java·spring boot·spring·ai