Files
JARVIS/development-doc/plan/agent-update/phase-5-advanced-features.md
WIN-JHFT4D3SIVT\caoxiaozhu a3fe4d24fc feat(agents): Phase 7-10 hook system, plugins, skills, orchestration
Phase 7: Built-in Hooks (audit_log, dangerous_confirmation, security_scan)
Phase 8: Plugin system (PluginManager, PluginSandbox, PluginManifest)
Phase 9: Skills registry (SkillRegistry, local/plugin/MCP loaders)
Phase 10: TeamLeader, RemoteTransport, BackgroundTaskManager
2026-04-04 22:56:27 +08:00

18 KiB
Raw Blame History

Phase 5高级特性Advanced Features

日期2026-04-03 状态:规划中


1. 阶段目标

Phase 5 包含一系列高级特性,在完成 Phase 1-4 后根据实际需求选择性实施。

这些特性不直接影响核心功能,但可以显著提升系统的可用性、安全性和可扩展性


2. 特性清单

2.1 Full Sandbox 隔离

目标实现完整的Docker级隔离

Phase 4已做Worktree隔离

Phase 5补充

  • 完整的容器生命周期管理
  • 资源限制(CPU/内存/网络)
  • 文件系统配额
  • 安全策略配置
class FullSandbox:
    """完整沙箱隔离"""
    
    async def execute(
        self,
        task: Task,
        config: SandboxConfig
    ) -> TaskResult:
        """
        在完整沙箱中执行
        
        特点:
        - 完全隔离的网络
        - 资源限制
        - 持久化存储(可选)
        - 安全策略
        """
        
        # 1. 创建容器
        container = await self.client.containers.run(
            image=config.image,
            detach=True,
            mem_limit=config.memory_limit,
            cpu_period=config.cpu_period,
            network_mode="isolated",  # 完全隔离网络
            volumes=config.volumes,
        )
        
        try:
            # 2. 执行任务
            result = await self._execute_in_container(container, task)
            return result
            
        finally:
            # 3. 清理
            await container.remove(force=True)

2.2 Persistence 层

目标将Event/Message持久化到数据库

Phase 1-3已做内存trace

Phase 5补充

  • Event持久化存储
  • Message持久化存储
  • 支持历史查询
  • 数据导出/归档
class EventPersistence:
    """事件持久化"""
    
    async def save_event(self, event: Event):
        """保存事件到数据库"""
        ...
    
    async def query_events(
        self,
        conversation_id: str,
        event_types: list[str] | None = None,
        start_time: datetime | None = None,
        end_time: datetime | None = None,
        limit: int = 100
    ) -> list[Event]:
        """查询历史事件"""
        ...

class MessagePersistence:
    """消息持久化"""
    
    async def save_message(self, message: AgentMessage):
        """保存消息到数据库"""
        ...
    
    async def get_thread_history(
        self,
        thread_id: str,
        limit: int = 100
    ) -> list[AgentMessage]:
        """获取线程历史"""
        ...

2.3 Multi-turn Memory

目标:支持跨会话的长期记忆

当前每个会话独立memory

Phase 5补充

  • 重要信息提取
  • 跨会话上下文复用
  • 知识更新机制
  • 遗忘策略
class MultiTurnMemory:
    """跨会话记忆"""
    
    def extract_important_info(
        self,
        conversation_summary: str,
        user_profile: UserProfile
    ) -> list[MemoryEntry]:
        """从对话中提取重要信息"""
        ...
    
    async def get_relevant_context(
        self,
        current_request: str,
        user_id: str
    ) -> list[MemoryEntry]:
        """获取与当前请求相关的记忆"""
        ...
    
    def update_memory(
        self,
        user_id: str,
        new_info: MemoryEntry
    ):
        """更新记忆"""
        ...
    
    def decay_old_memories(self, user_id: str):
        """遗忘旧记忆"""
        ...

2.4 Cost Monitoring

目标实时监控Token成本

Phase 3已有Budget模型

Phase 5补充

  • 实时Token计数
  • 成本估算
  • 告警机制
  • 使用报告
class CostMonitor:
    """成本监控"""
    
    async def track_usage(
        self,
        conversation_id: str,
        model: str,
        input_tokens: int,
        output_tokens: int
    ):
        """跟踪使用量"""
        ...
    
    async def estimate_cost(
        self,
        conversation_id: str
    ) -> CostEstimate:
        """估算当前会话成本"""
        ...
    
    async def check_budget(
        self,
        user_id: str,
        expected_tokens: int
    ) -> bool:
        """检查预算是否足够"""
        ...
    
    async def send_alert(
        self,
        user_id: str,
        threshold: float
    ):
        """发送告警"""
        ...

# 使用示例
@dataclass
class CostEstimate:
    total_tokens: int
    estimated_cost: float
    breakdown: dict[str, int]  # per-model
    threshold_percent: float  # 相对于用户限额

2.5 Advanced UI

目标:完整的前端协作面板

Phase 4已有API

Phase 5补充

  • 实时协作拓扑图
  • Agent对话界面
  • 任务看板
  • 成本仪表盘
┌────────────────────────────────────────────────────────────────────┐
│  Jarvis 协作面板                                                    │
├────────────────────────────────────────────────────────────────────┤
│                                                                     │
│  ┌─────────────┐    ┌─────────────────────────────────────────────┐ │
│  │ 拓扑图      │    │ 当前会话                                    │ │
│  │             │    │                                             │ │
│  │ [Master]    │    │ User: 帮我分析这个项目...                    │ │
│  │    │        │    │                                             │ │
│  │ [Coord]    │    │ [Coordinator]: 拆分为3个子任务              │ │
│  │  ┌─┴─┐    │    │   - Task 1: 检索相关知识                    │ │
│  │  │   │    │    │   - Task 2: 执行分析                       │ │
│  │ [W1] [W2] │    │   - Task 3: 汇总报告                       │ │
│  │             │    │                                             │ │
│  │ 点击查看详情 │    │ [Worker-1]: 正在检索...                    │ │
│  └─────────────┘    └─────────────────────────────────────────────┘ │
│                                                                     │
│  ┌─────────────┐    ┌─────────────────────────────────────────────┐ │
│  │ 任务列表    │    │ 成本监控                                    │ │
│  │             │    │                                             │ │
│  │ ☑ Task 1   │    │ Token: 12,345 / 50,000                   │ │
│  │ ◐ Task 2   │    │ 成本: $0.23 / $5.00                       │ │
│  │ ○ Task 3   │    │ [████████████████░░░░░] 24%              │ │
│  └─────────────┘    └─────────────────────────────────────────────┘ │
│                                                                     │
└────────────────────────────────────────────────────────────────────┘

2.6 Plugin System

目标:支持第三方插件扩展

设计参考Claude Code CLI的插件系统

class PluginSystem:
    """插件系统"""
    
    async def load_plugin(self, plugin_path: str) -> Plugin:
        """加载插件"""
        ...
    
    async def execute_plugin(
        self,
        plugin_id: str,
        context: dict
    ) -> Any:
        """执行插件"""
        ...

@dataclass
class Plugin:
    """插件定义"""
    plugin_id: str
    name: str
    version: str
    capabilities: list[str]  # 提供的工具/能力
    hooks: list[str]  # 生命周期钩子
    
    async def execute(self, context: dict) -> Any:
        ...

@dataclass
class PluginManifest:
    """插件清单"""
    tools: list[ToolManifest]
    commands: list[CommandManifest]
    hooks: list[str]

2.7 TagMemo — 仿生记忆系统

目标:实现基于遗忘曲线的智能记忆系统

设计参考VCPToolBox的TagMemo V6/V7 RAG系统

核心概念

  1. LIF神经元模型 — 脉冲传播机制

    • 记忆不是静态存储,而是动态激活
    • 重要记忆获得更高的激活频率
  2. Core Tags vs Normal Tags — 核心记忆

    • Core Tags获得1.2-1.4x权重加成
    • 核心记忆有虚拟召回能力
  3. 遗忘曲线 — 不是无限存储

    • 模拟生物遗忘,不是简单删除
    • 基于重要性动态计算衰减率
class MemoryImportance(str, Enum):
    """记忆重要性等级"""
    CORE = "core"      # 核心记忆1.2-1.4x权重
    HIGH = "high"      # 高重要性
    MEDIUM = "medium"  # 中等重要性
    LOW = "low"        # 低重要性,会自然遗忘

@dataclass
class TagMemoEntry:
    """TagMemo记忆条目"""
    entry_id: str
    content: str
    
    # VCPToolBox借鉴
    importance: MemoryImportance = MemoryImportance.MEDIUM
    decay_rate: float = 0.1  # 遗忘率
    last_activated: datetime = field(default_factory=datetime.now)
    activation_count: int = 0  # 激活次数
    
    # EPA模块可选
    logic_depth: int = 0  # 逻辑深度
    resonance_score: float = 0.0  # 共振分数

class TagMemoMemory:
    """
    仿生记忆系统
    
    特点:
    - 遗忘曲线模拟
    - 重要性权重
    - 动态激活
    """
    
    async def add_memory(
        self,
        content: str,
        importance: MemoryImportance = MemoryImportance.MEDIUM,
        tags: list[str] | None = None
    ) -> TagMemoEntry:
        """添加记忆"""
        entry = TagMemoEntry(
            entry_id=generate_id(),
            content=content,
            importance=importance,
            decay_rate=self._calculate_decay_rate(importance),
            tags=tags or []
        )
        await self._storage.save(entry)
        return entry
    
    def should_retain(self, entry: TagMemoEntry, days_elapsed: int) -> bool:
        """
        判断记忆是否应该保留
        
        基于动态Beta公式
        β = σ(L·log(1+R) - S·noise_penalty)
        """
        if entry.importance == MemoryImportance.CORE:
            return True  # 核心记忆永远保留
        
        # 遗忘概率 = 基础衰减 × 时间 × 噪声惩罚
        retention_prob = math.exp(
            -entry.decay_rate * days_elapsed * self._noise_factor
        )
        return random.random() < retention_prob
    
    async def get_relevant_memories(
        self,
        query: str,
        limit: int = 5
    ) -> list[TagMemoEntry]:
        """获取相关记忆(带权重)"""
        candidates = await self._vector_search(query, limit=limit * 2)
        
        # 按重要性权重排序
        weighted = []
        for entry in candidates:
            weight = self._calculate_weight(entry)
            weighted.append((entry, weight))
        
        weighted.sort(key=lambda x: x[1], reverse=True)
        return [e for e, _ in weighted[:limit]]
    
    def _calculate_weight(self, entry: TagMemoEntry) -> float:
        """计算记忆权重"""
        base = 1.0
        
        # 重要性权重
        if entry.importance == MemoryImportance.CORE:
            base *= 1.3
        elif entry.importance == MemoryImportance.HIGH:
            base *= 1.1
        
        # 激活频率奖励
        base *= (1 + math.log(1 + entry.activation_count))
        
        # 时间衰减
        days = (datetime.now() - entry.last_activated).days
        base *= math.exp(-0.01 * days)
        
        return base

2.8 AgentDream — 仿生梦境系统

目标AI在"睡眠"时自动整理和巩固记忆

设计参考VCPToolBox的AgentDream bijective morphic system

三层时间记忆涟漪

时间层 范围 特点
短期记忆 0-7天 高频共振,快速激活
中期记忆 7-90天 弱共振,需要触发
长期记忆 >90天 遗忘边界,需要特殊唤醒
class DreamLayer(str, Enum):
    """梦境记忆层"""
    SHORT_TERM = "short_term"   # 0-7天
    MID_TERM = "mid_term"       # 7-90天
    LONG_TERM = "long_term"     # >90天

@dataclass
class DreamMemory:
    """梦境记忆结构"""
    layer: DreamLayer
    resonance_bridges: list[str] = field(default_factory=list)  # 共振桥接
    consolidation_level: float = 0.0  # 巩固程度 0-1

class AgentDreamEngine:
    """
    仿生梦境引擎
    
    功能:
    - 定时触发记忆整理
    - 跨层共振发现
    - 遗忘边界管理
    """
    
    async def dream(self, user_id: str) -> DreamReport:
        """
        执行梦境整理
        
        流程:
        1. 获取近期记忆0-7天
        2. 与中期记忆建立共振桥
        3. 评估哪些记忆应该升级/遗忘
        4. 生成梦境叙事报告
        """
        short_term = await self._get_memories(
            user_id, 
            layer=DreamLayer.SHORT_TERM
        )
        mid_term = await self._get_memories(
            user_id, 
            layer=DreamLayer.MID_TERM
        )
        
        # 发现共振
        bridges = await self._discover_resonance_bridges(
            short_term, mid_term
        )
        
        # 评估记忆
        to_promote = []  # 升级到中期
        to_forget = []   # 标记遗忘
        to_consolidate = []  # 巩固
        
        for memory in short_term:
            if memory.activation_count > 10:
                to_promote.append(memory)
            elif memory.activation_count < 2:
                to_forget.append(memory)
            else:
                to_consolidate.append(memory)
        
        # 执行整理
        await self._promote_memories(to_promote)
        await self._apply_forgetting(to_forget)
        await self._consolidate(to_consolidate, bridges)
        
        # 生成梦境报告
        return await self._generate_dream_narrative(
            promoted=to_promote,
            forgotten=to_forget,
            bridges=bridges
        )
    
    async def _discover_resonance_bridges(
        self,
        short_term: list[TagMemoEntry],
        mid_term: list[TagMemoEntry]
    ) -> list[tuple[TagMemoEntry, TagMemoEntry, float]]:
        """发现跨层共振桥接"""
        bridges = []
        
        for s in short_term:
            for m in mid_term:
                similarity = await self._calculate_resonance(s, m)
                if similarity > 0.7:
                    bridges.append((s, m, similarity))
        
        return bridges
    
    async def _generate_dream_narrative(
        self,
        promoted: list,
        forgotten: list,
        bridges: list
    ) -> DreamReport:
        """生成第一人称梦境叙事"""
        narrative = f"""
        【梦境记录】
        
        今夜整理了{len(promoted)}段重要记忆,它们已经被巩固:
        {', '.join(m.content for m in promoted[:3])}
        
        发现了{len(bridges)}条记忆共振:
        {self._describe_bridges(bridges)}
        
        {len(forgotten)}段记忆正在消散...
        """
        
        return DreamReport(
            narrative=narrative,
            promoted_count=len(promoted),
            forgotten_count=len(forgotten),
            bridges_count=len(bridges)
        )

触发机制

# 定时任务每天凌晨3点执行梦境整理
@scheduler.scheduled(cron="0 3 * * *")
async def scheduled_agent_dream():
    """AI睡眠时整理记忆"""
    for user_id in await get_active_users():
        try:
            report = await agent_dream_engine.dream(user_id)
            logger.info(f"Dream complete for {user_id}: {report.summary}")
        except Exception as e:
            logger.error(f"Dream failed for {user_id}: {e}")

3. 实施优先级

特性 优先级 依赖 建议实施时机
Cost Monitoring 🔴 Phase 3 正式上线前
TagMemo 🟡 Phase 2 用户反馈需要更好记忆时
AgentDream 🟢 Phase 5+TagMemo 凌晨调度资源时
Persistence 🟡 Phase 1-3 有审计需求时
Multi-turn Memory 🟡 Phase 1-2 用户反馈需要时
Advanced UI 🟡 Phase 4 有前端资源时
Full Sandbox 🟢 Phase 4 有安全需求时
Plugin System 🟢 Phase 1 有社区需求时

4. 风险点

风险 缓解措施
功能蔓延 严格控制每个特性的scope
性能影响 Persistence要考虑异步和索引优化
成本增加 Full Sandbox资源限制要明确

5. 验收标准

特性 验收标准
Cost Monitoring 能实时显示Token使用量和估算成本
Persistence 事件和消息可持久化存储和查询
Multi-turn Memory 跨会话可复用关键信息
Advanced UI 有可用的前端协作面板
Full Sandbox 容器隔离完整,资源限制生效
Plugin System 插件可加载和执行

6. 本阶段完成后预期结果

完成后Jarvis 将具备:

  • 完整的成本监控能力
  • 仿生记忆系统TagMemo
  • AI梦境整理AgentDream
  • 历史数据持久化
  • 跨会话的智能记忆
  • 完整的协作可视化UI
  • 高级隔离执行环境
  • 可扩展的插件系统

Phase 5 为可选特性,根据实际需求选择性实施。