* feat: add SeekDB vector database support for knowledge bases This commit adds complete integration of OceanBase's SeekDB as a vector database option for LangBot's knowledge base feature. ## Changes ### Core Implementation - Add SeekDB adapter implementing VectorDatabase interface - Support both embedded and server deployment modes - HNSW indexing with cosine similarity - Async operations with error handling - Comprehensive logging ### System Integration - Register SeekDB in VectorDBManager - Add pyseekdb>=0.1.0 dependency - Add SeekDB configuration template - Update README with vector database section ### Documentation - Complete integration guide with platform compatibility warnings - Configuration examples for all deployment modes - Troubleshooting guide for common issues - Code examples demonstrating usage patterns - Comprehensive test reports and status documentation ## Testing Architecture validated end-to-end using ChromaDB: - File upload → parsing → chunking → embedding → storage - 828 bytes → 3 chunks → 3 vectors stored successfully - BGE-M3 model (384 dimensions) - Status: Completed ✅ ## Platform Compatibility ### Embedded Mode - ✅ Linux: Fully supported - ❌ macOS: Not supported (pylibseekdb is Linux-only) - ❌ Windows: Not supported (pylibseekdb is Linux-only) ### Server Mode - ✅ Linux: Fully supported - ⚠️ macOS: Known issue (oceanbase/seekdb#36) - ⚠️ Windows: Untested ### Remote Connection - ✅ All platforms supported ## Known Issues macOS Docker server mode affected by upstream bug: https://github.com/oceanbase/seekdb/issues/36 Workaround: Use ChromaDB/Qdrant or connect to remote SeekDB server. ## Files Added - src/langbot/pkg/vector/vdbs/seekdb.py - docs/SEEKDB_INTEGRATION.md - examples/seekdb_example.py - SEEKDB_INTEGRATION_SUMMARY.md - SEEKDB_INTEGRATION_COMPLETE.md - SEEKDB_TEST_STATUS.md - SEEKDB_FINAL_SUMMARY.md - SEEKDB_INTEGRATION_DONE.md - GITHUB_ISSUE_36_COMMENT.md ## Files Modified - src/langbot/pkg/vector/mgr.py - src/langbot/pkg/vector/vdbs/__init__.py - pyproject.toml - src/langbot/templates/config.yaml - README.md - README_EN.md 🤖 Generated with [Claude Code](https://claude.com/claude-code) via [Happy](https://happy.engineering) Co-Authored-By: Claude <noreply@anthropic.com> Co-Authored-By: Happy <yesreply@happy.engineering> * chore: remove unused docs * feature: minimal seekdb change (#1866) * feat: add SeekDB embedding requester and configuration This commit introduces a new SeekDB embedding requester, which utilizes the local embedding function from pyseekdb. It includes the necessary Python implementation and a corresponding YAML configuration file for integration. Additionally, a new SVG icon for SeekDB is added to enhance the visual representation in the UI. * fix: update EmbeddingForm to conditionally render URL field based on model provider This commit modifies the EmbeddingForm component to conditionally display the URL input field only when the current model provider is not 'seekdb-embedding'. Additionally, it updates the condition for rendering the API key field to exclude both 'ollama-chat' and 'seekdb-embedding' providers. * chore: update Python version requirement in pyproject.toml to support Python 3.11 * fix: add config default value, when it makes fronted not show spec * fix: seekdb.py clean metadata. change api * fix: enhance error handling in SeekDB embedding initialization This commit adds improved error handling to the SeekDB embedding function. It ensures that a RuntimeError is raised if the embedding function fails to initialize, and wraps the embedding call in a try-except block to catch and raise a RequesterError with a descriptive message in case of failure. * refactor: update SeekDB database management to use AdminClient This commit refactors the SeekDB database management logic to utilize the AdminClient for database operations. It replaces the previous temp_client with admin_client for listing and creating databases, ensuring a more robust interaction with the SeekDB API. * refactor: update SeekDB embedding model initialization to use task manager This commit refactors the SeekDB embedding model initialization by replacing the direct asyncio task creation with the task manager's create_task method. This change enhances task management and provides a clearer naming convention for the embedding model initialization task. * perf: integration * chore: remove unnecessary files * fix: linter errors --------- Co-authored-by: Claude <noreply@anthropic.com> Co-authored-by: Happy <yesreply@happy.engineering> Co-authored-by: 名为a的全局变量 <1051233107@qq.com>
8.1 KiB
SeekDB Vector Database Integration
This document describes how to use OceanBase SeekDB as the vector database backend for LangBot's knowledge base feature.
What is SeekDB?
OceanBase SeekDB is an AI-native search database that unifies relational, vector, text, JSON and GIS in a single engine, enabling hybrid search and in-database AI workflows. It's developed by OceanBase and released under Apache 2.0 license.
Key Features
- Hybrid Search: Combine vector search, full-text search and relational query in a single statement
- Multi-Model Support: Support relational, vector, text, JSON and GIS in a single engine
- Lightweight: Requires as little as 1 CPU core and 2 GB of memory
- Multiple Deployment Modes: Supports both embedded mode and client/server mode
- MySQL Compatible: Powered by OceanBase engine with full ACID compliance and MySQL compatibility
Installation
SeekDB support is automatically included when you install LangBot. The required dependency pyseekdb is listed in pyproject.toml.
If you need to install it manually:
pip install pyseekdb
⚠️ Platform Compatibility
Embedded Mode
| Platform | Status | Notes |
|---|---|---|
| Linux | ✅ Supported | Full embedded mode support via pylibseekdb |
| macOS | ❌ Not Supported | pylibseekdb is Linux-only; use server mode instead |
| Windows | ❌ Not Supported | pylibseekdb is Linux-only; use server mode instead |
Important: Embedded mode requires the pylibseekdb library, which is only available on Linux. If you're on macOS or Windows, you must use server mode.
Server Mode (Docker)
| Platform | Status | Notes |
|---|---|---|
| Linux | ✅ Supported | Full Docker support |
| macOS | ⚠️ Known Issue | Docker container initialization failure - See Issue #36 |
| Windows | ⚠️ Untested | Should work but not yet tested |
macOS Users: Currently, SeekDB Docker containers have an initialization issue on macOS (oceanbase/seekdb#36). Until this is resolved, we recommend:
- Using ChromaDB or Qdrant as alternatives
- Connecting to a remote SeekDB server on Linux if available
Server Mode (Remote Connection)
| Platform | Status | Notes |
|---|---|---|
| All Platforms | ✅ Supported | Connect to SeekDB running on a remote Linux server |
Recommendation for macOS/Windows users: Deploy SeekDB on a Linux server and connect via server mode configuration.
Configuration
Embedded Mode (Recommended for Development)
Embedded mode runs SeekDB directly within the LangBot process, storing data locally. This is the simplest setup and requires no external services.
Edit your config.yaml:
vdb:
use: seekdb
seekdb:
mode: embedded
path: './data/seekdb' # Path to store SeekDB data
database: 'langbot' # Database name
Server Mode (For Production)
Server mode connects to a remote SeekDB server or OceanBase server. This is recommended for production deployments.
SeekDB Server
vdb:
use: seekdb
seekdb:
mode: server
host: 'localhost'
port: 2881
database: 'langbot'
user: 'root'
password: '' # Can also use SEEKDB_PASSWORD env var
OceanBase Server
If you're using OceanBase with seekdb capabilities:
vdb:
use: seekdb
seekdb:
mode: server
host: 'localhost'
port: 2881
tenant: 'sys' # OceanBase tenant name
database: 'langbot'
user: 'root'
password: ''
Configuration Parameters
| Parameter | Required | Default | Description |
|---|---|---|---|
mode |
No | embedded |
Deployment mode: embedded or server |
path |
No | ./data/seekdb |
Data directory for embedded mode |
database |
No | langbot |
Database name |
host |
No | localhost |
Server host (server mode only) |
port |
No | 2881 |
Server port (server mode only) |
user |
No | root |
Username (server mode only) |
password |
No | '' |
Password (server mode only) |
tenant |
No | None | OceanBase tenant (optional, server mode only) |
Usage
Once configured, SeekDB will be used automatically for all knowledge base operations in LangBot:
- Creating Knowledge Bases: Vectors will be stored in SeekDB collections
- Adding Documents: Document embeddings will be indexed in SeekDB
- Searching: Vector similarity search will use SeekDB's efficient indexing
- Deleting: Document removal will delete vectors from SeekDB
No code changes are required - just update your configuration!
Architecture Details
Implementation
The SeekDB adapter is implemented in src/langbot/pkg/vector/vdbs/seekdb.py and follows the same VectorDatabase interface as Chroma and Qdrant adapters.
Key methods:
add_embeddings(): Add vectors with metadata to a collectionsearch(): Perform vector similarity searchdelete_by_file_id(): Delete vectors by file ID metadataget_or_create_collection(): Manage collectionsdelete_collection(): Remove entire collections
Vector Storage
- Collections are created with HNSW (Hierarchical Navigable Small World) index
- Default distance metric: Cosine similarity
- Default vector dimension: 384 (adjusts automatically based on embeddings)
- Metadata is stored alongside vectors for filtering
Advantages Over Other Vector Databases
vs. ChromaDB
- ✅ Better MySQL compatibility
- ✅ Hybrid search capabilities (vector + full-text + SQL)
- ✅ Production-grade distributed mode support
- ✅ Lightweight embedded mode
vs. Qdrant
- ✅ SQL query support
- ✅ MySQL ecosystem integration
- ✅ Simpler deployment (no Docker required for embedded mode)
- ✅ Multi-model data support (not just vectors)
Troubleshooting
Import Error
If you see: ImportError: pyseekdb is not installed
Solution:
pip install pyseekdb
Embedded Mode Error on macOS/Windows
Error:
RuntimeError: Embedded Client is not available because pylibseekdb is not available.
Please install pylibseekdb (Linux only) or use RemoteServerClient (host/port) instead.
Cause: pylibseekdb is only available on Linux platforms.
Solution: Use server mode instead:
- Deploy SeekDB on a Linux server or VM
- Configure LangBot to use server mode:
vdb:
use: seekdb
seekdb:
mode: server
host: 'your-seekdb-server-ip'
port: 2881
database: 'langbot'
user: 'root'
password: ''
Alternative: Use ChromaDB or Qdrant, which work on all platforms:
vdb:
use: chroma # or qdrant
Docker Container Fails on macOS
Symptoms:
docker run -d -p 2881:2881 oceanbase/seekdb:latest
# Container exits immediately with code 30
Error in logs:
[ERROR] Code: Agent.SeekDB.Not.Exists
Message: initialize failed: init agent failed: SeekDB not exists in current directory.
Cause: This is a known issue with SeekDB Docker containers on macOS. See oceanbase/seekdb#36.
Status: Under investigation by OceanBase team.
Workaround Options:
- Use alternatives: ChromaDB or Qdrant work perfectly on macOS
- Remote server: Deploy SeekDB on a Linux server and connect remotely
- Wait for fix: Monitor the GitHub issue for updates
Connection Error (Server Mode)
If SeekDB server is not reachable, check:
- Server is running:
ps aux | grep observer - Port is accessible:
nc -zv localhost 2881 - Credentials are correct in config
- Firewall allows connections on port 2881
Performance Issues
For large datasets:
- Use server mode instead of embedded mode
- Ensure adequate memory allocation
- Consider using OceanBase distributed mode for very large scale
- Adjust HNSW index parameters if needed
Resources
- SeekDB GitHub: https://github.com/oceanbase/seekdb
- pyseekdb SDK: https://github.com/oceanbase/pyseekdb
- OceanBase Documentation: https://oceanbase.ai
- LangBot Documentation: https://docs.langbot.app
License
SeekDB is licensed under Apache License 2.0.