🇨🇳 简体中文
🇺🇸 English | 🇮🇳 हिंदी | 🇯🇵 日本語 | 🇨🇳 简体中文 | 🇪🇸 Español | 🇧🇷 Português (Brasil) | 🇰🇷 한국어 | 🇩🇪 Deutsch | 🇫🇷 Français
Note: 本文档是翻译版本。英文版
README.md是权威来源。
RAG Container Template

此仓库是一个用于构建本地 Retrieval-Augmented Generation(RAG) 系统的全栈沙盒。
后端是带有身份认证和 RAG API 的 FastAPI 服务,使用 ChromaDB 作为持久化向量存储,并使用 Ollama 进行嵌入生成和聊天。前端是一个与后端通信的 Expo / React Native 应用。
Features
- Backend
- FastAPI
- Frontend
- Expo / React-Native
- DataBase
- PostgreSQL
- RAG (Retrieval-Augmented Generation)
- 使用 Ollama 的 Embeddings
- 使用 ChromaDB 的 Vector store
- Chat / Answer generation
- DevOps
- Docker Compose
- GitHub Actions workflows
Architecture
+-----------------------------+
| Frontend (Expo) |
| - React Native app |
| - Calls backend /auth, |
| /items, /rag endpoints |
+--------------+--------------+
|
v
+-----------------------------+
| Backend (FastAPI) |
| - Auth & Items routers |
| - RAG router (/rag/...) |
| - SQLAlchemy + Postgres |
+--------------+--------------+
|
+-------+----------+
| |
v v
+-------------+ +------------------+
| ChromaDB | | Ollama (LLM) |
| Vector DB | | /api/chat |
| /chroma_db | | /api/embeddings |
+-------------+ +------------------+
🚀 Getting Started
1. Prerequisites
2. Build and start all services:
# set environment variables:
export REACT_NATIVE_PACKAGER_HOSTNAME=${YOUR_HOST}
# Build the image
docker compose build
# Run the container
docker compose up
3. Test:
# Backend pytest
docker compose \
-f docker-compose.test.yml run \
--rm \
--entrypoint /bin/sh backend_test \
-lc 'pytest -q'
# Backend Lint
docker compose \
-f docker-compose.test.yml run \
--rm \
--entrypoint /bin/sh backend_test \
-lc 'ruff check /app /tests'
# Frontend Test
docker compose \
-f docker-compose.test.yml run \
--rm frontend_test
Visit the services:
-
Backend API: http://localhost:8000/docs

- Frontend UI (WEB): http://localhost:8081
- Frontend UI (mobile): exp://${YOUR_HOST}:8081: 使用 Expo 提供的 QR 码访问。

RAG API
Ingest documents
POST /rag/ingest
curl -X POST http://localhost:8000/rag/ingest \
-H "Content-Type: application/json" \
-d '{
"documents": [
{
"id": "miura_intro_001",
"text": "Miura Peninsula is located in Kanagawa, south of Yokohama. It is famous for its coastline, fresh seafood, and views of Mount Fuji on clear days.",
"source": "local-notes"
}
]
}'
Response:
{
"total_chunks": 1
}
Ask a question
POST /rag/query
curl -X POST http://localhost:8000/rag/query \
-H "Content-Type: application/json" \
-d '{
"question": "Where is the Miura Peninsula and what is it famous for?",
"top_k": 5
}'
Example response:
{
"answer": "The Miura Peninsula is in Kanagawa, south of Yokohama. It is known for its coastline, fresh seafood, and views of Mount Fuji on clear days.",
"chunks": [
{
"id": "miura_intro_001_0",
"text": "...",
"source": "local-notes",
"chunk_index": 0,
"distance": 0.01
}
]
}
License
- Apache License 2.0