Files
assistant/docker-compose.yml
wangliang 965b11316e feat: 添加图片搜索功能和 Qwen 模型支持
图片搜索功能(以图搜图):
- Chatwoot webhook 检测图片搜索消息 (content_type="search_image")
- 从 content_attributes.url 提取图片 URL
- 调用 Mall API 图片搜索接口 (/mall/api/spu?searchImageUrl=...)
- 支持嵌套和顶层 URL 位置提取
- Product Agent 添加 fast path 直接调用图片搜索工具
- 防止无限循环(使用后清除 context.image_search_url)

Qwen 模型支持:
- 添加 LLM provider 选择(zhipu/qwen)
- 实现 QwenLLMClient 类(基于 DashScope SDK)
- 添加 dashscope>=1.14.0 依赖
- 修复 API key 设置(直接设置 dashscope.api_key)
- 更新 .env.example 和 docker-compose.yml 配置

其他优化:
- 重构 Chatwoot 集成代码(删除冗余)
- 优化 Product Agent prompt
- 增强 Customer Service Agent 多语言支持

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-01-27 19:10:06 +08:00

182 lines
4.8 KiB
YAML

version: '3.8'
services:
# ============ Infrastructure ============
# Redis (Cache & Queue) - Agent 和 MCP 服务都需要
redis:
image: redis:7-alpine
container_name: ai_redis
command: redis-server --appendonly yes
volumes:
- redis_data:/data
networks:
- ai_network
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 3s
retries: 5
restart: unless-stopped
# ============ AI Agent Layer ============
# LangGraph Agent Main Service
agent:
build:
context: ./agent
dockerfile: Dockerfile
container_name: ai_agent
environment:
# AI Model
LLM_PROVIDER: ${LLM_PROVIDER:-zhipu}
ZHIPU_API_KEY: ${ZHIPU_API_KEY}
ZHIPU_MODEL: ${ZHIPU_MODEL:-glm-4-flash}
QWEN_API_KEY: ${QWEN_API_KEY}
QWEN_MODEL: ${QWEN_MODEL:-qwen-omni-turbo}
# Redis
REDIS_HOST: redis
REDIS_PORT: 6379
REDIS_PASSWORD: ${REDIS_PASSWORD}
REDIS_DB: 0
# Chatwoot (远程服务器)
CHATWOOT_API_URL: ${CHATWOOT_API_URL}
CHATWOOT_API_TOKEN: ${CHATWOOT_API_TOKEN}
CHATWOOT_WEBHOOK_SECRET: ${CHATWOOT_WEBHOOK_SECRET}
# External APIs
STRAPI_API_URL: ${STRAPI_API_URL}
STRAPI_API_TOKEN: ${STRAPI_API_TOKEN}
HYPERF_API_URL: ${HYPERF_API_URL}
HYPERF_API_TOKEN: ${HYPERF_API_TOKEN}
# Mall API
MALL_API_URL: ${MALL_API_URL}
MALL_TENANT_ID: ${MALL_TENANT_ID:-2}
MALL_CURRENCY_CODE: ${MALL_CURRENCY_CODE:-EUR}
MALL_LANGUAGE_ID: ${MALL_LANGUAGE_ID:-1}
MALL_SOURCE: ${MALL_SOURCE:-us.qa1.gaia888.com}
# Frontend URLs
FRONTEND_URL: ${FRONTEND_URL:-https://www.qa1.gaia888.com}
# MCP Servers
STRAPI_MCP_URL: http://strapi_mcp:8001
ORDER_MCP_URL: http://order_mcp:8002
AFTERSALE_MCP_URL: http://aftersale_mcp:8003
PRODUCT_MCP_URL: http://product_mcp:8004
# Config
LOG_LEVEL: ${LOG_LEVEL:-INFO}
MAX_CONVERSATION_STEPS: ${MAX_CONVERSATION_STEPS:-10}
CONVERSATION_TIMEOUT: ${CONVERSATION_TIMEOUT:-3600}
ports:
- "8000:8000"
volumes:
- ./agent:/app
- agent_logs:/app/logs
depends_on:
- redis
- strapi_mcp
- order_mcp
- aftersale_mcp
- product_mcp
networks:
- ai_network
restart: unless-stopped
# ============ MCP Servers ============
# Strapi MCP (FAQ/Knowledge Base)
strapi_mcp:
build:
context: ./mcp_servers/strapi_mcp
dockerfile: Dockerfile
container_name: ai_strapi_mcp
environment:
STRAPI_API_URL: ${STRAPI_API_URL}
STRAPI_API_TOKEN: ${STRAPI_API_TOKEN}
LOG_LEVEL: ${LOG_LEVEL:-INFO}
ports:
- "8001:8001"
volumes:
- ./mcp_servers/strapi_mcp:/app
- ./mcp_servers/shared:/app/shared
networks:
- ai_network
restart: unless-stopped
# Order MCP
order_mcp:
build:
context: ./mcp_servers/order_mcp
dockerfile: Dockerfile
container_name: ai_order_mcp
env_file:
- .env
environment:
HYPERF_API_URL: ${HYPERF_API_URL}
HYPERF_API_TOKEN: ${HYPERF_API_TOKEN}
MALL_API_URL: ${MALL_API_URL}
MALL_TENANT_ID: ${MALL_TENANT_ID:-2}
MALL_CURRENCY_CODE: ${MALL_CURRENCY_CODE:-EUR}
MALL_LANGUAGE_ID: ${MALL_LANGUAGE_ID:-1}
MALL_SOURCE: ${MALL_SOURCE:-us.qa1.gaia888.com}
LOG_LEVEL: ${LOG_LEVEL:-INFO}
ports:
- "8002:8002"
volumes:
- ./mcp_servers/order_mcp:/app
- ./mcp_servers/shared:/app/shared
networks:
- ai_network
restart: unless-stopped
# Aftersale MCP
aftersale_mcp:
build:
context: ./mcp_servers/aftersale_mcp
dockerfile: Dockerfile
container_name: ai_aftersale_mcp
environment:
HYPERF_API_URL: ${HYPERF_API_URL}
HYPERF_API_TOKEN: ${HYPERF_API_TOKEN}
LOG_LEVEL: ${LOG_LEVEL:-INFO}
ports:
- "8003:8003"
volumes:
- ./mcp_servers/aftersale_mcp:/app
- ./mcp_servers/shared:/app/shared
networks:
- ai_network
restart: unless-stopped
# Product MCP
product_mcp:
build:
context: ./mcp_servers/product_mcp
dockerfile: Dockerfile
container_name: ai_product_mcp
env_file:
- .env
environment:
HYPERF_API_URL: ${HYPERF_API_URL}
HYPERF_API_TOKEN: ${HYPERF_API_TOKEN}
MALL_API_URL: ${MALL_API_URL}
MALL_TENANT_ID: ${MALL_TENANT_ID:-2}
MALL_CURRENCY_CODE: ${MALL_CURRENCY_CODE:-EUR}
MALL_LANGUAGE_ID: ${MALL_LANGUAGE_ID:-1}
MALL_SOURCE: ${MALL_SOURCE:-us.qa1.gaia888.com}
LOG_LEVEL: ${LOG_LEVEL:-INFO}
ports:
- "8004:8004"
volumes:
- ./mcp_servers/product_mcp:/app
- ./mcp_servers/shared:/app/shared
networks:
- ai_network
restart: unless-stopped
networks:
ai_network:
driver: bridge
volumes:
redis_data:
agent_logs: