fix: ensure atomic creation of knowledge base with proper cleanup on failure (#4406)

* fix: ensure atomic creation of knowledge base with proper cleanup on failure

- Added pre-validation for embedding_provider_id parameter
- Added check for existing knowledge base with same name
- Implemented proper rollback mechanism when KBHelper initialization fails
- Uses same session for cleanup to ensure data consistency
- Fixes #4403

* fix: ensure atomic KB creation with session.flush() to remove race condition risks

* fix: ensure change the annotation back
This commit is contained in:
Li-shi-ling
2026-01-11 14:24:26 +08:00
committed by GitHub
parent 81309bc908
commit 9a91f2fb11
+21 -14
View File
@@ -92,6 +92,8 @@ class KnowledgeBaseManager:
top_m_final: int | None = None,
) -> KBHelper:
"""创建新的知识库实例"""
if embedding_provider_id is None:
raise ValueError("创建知识库时必须提供embedding_provider_id")
kb = KnowledgeBase(
kb_name=kb_name,
description=description,
@@ -104,21 +106,26 @@ class KnowledgeBaseManager:
top_k_sparse=top_k_sparse if top_k_sparse is not None else 50,
top_m_final=top_m_final if top_m_final is not None else 5,
)
async with self.kb_db.get_db() as session:
session.add(kb)
await session.commit()
await session.refresh(kb)
try:
async with self.kb_db.get_db() as session:
session.add(kb)
await session.flush()
kb_helper = KBHelper(
kb_db=self.kb_db,
kb=kb,
provider_manager=self.provider_manager,
kb_root_dir=FILES_PATH,
chunker=CHUNKER,
)
await kb_helper.initialize()
self.kb_insts[kb.kb_id] = kb_helper
return kb_helper
kb_helper = KBHelper(
kb_db=self.kb_db,
kb=kb,
provider_manager=self.provider_manager,
kb_root_dir=FILES_PATH,
chunker=CHUNKER,
)
await kb_helper.initialize()
await session.commit()
self.kb_insts[kb.kb_id] = kb_helper
return kb_helper
except Exception as e:
if "kb_name" in str(e):
raise ValueError(f"知识库名称 '{kb_name}' 已存在")
raise
async def get_kb(self, kb_id: str) -> KBHelper | None:
"""获取知识库实例"""