乐于分享
好东西不私藏

四千行代码如何实现一个精简OpenClaw?Nanobot核心架构解析

四千行代码如何实现一个精简OpenClaw?Nanobot核心架构解析
框架核心代码量功能完整度定制门槛资源占用
nanobot~4000 行全功能 Agent极低(改配置即可)极低
OpenClaw~40 万行全功能 Agent中高
LangChain数十万行工具链丰富中高
AutoGPT数万行自动化能力强中高

在AI Agent领域,坊间流传着一个“不可能三角”:功能强大、代码简洁、易于定制,三者似乎永远不可兼得。nanobot 仅用约4000行代码,就实现了一个功能完备的AI助手,比OpenClaw小了99%。

笔者最近用AI阅读了nanobot的源码,被其精巧的设计打动。今天将带大家一探究竟,看看这4000行代码背后隐藏着怎样的架构智慧。这篇文章面向有一定编程基础的工程师,力求做到既深入又通俗。

一、整体架构:一个“小而美”的Agent系统

在深入代码之前,我们先从宏观角度理解nanobot的架构设计。nanobot采用模块化设计,核心组件各司其职,通过清晰定义的接口进行交互。

从目录结构就能感受到这种设计思路:

nanobot/├── agent/           # 核心Agent逻辑│   ├── loop.py      # Agent主循环│   ├── context.py   # 上下文构建│   ├── memory.py    # 记忆系统│   ├── skills.py    # 技能加载器│   ├── subagent.py  # 子代理管理│   └── tools/       # 内置工具集├── providers/        # LLM提供者├── channels/        # 通讯渠道(飞书、QQ等十多款)├── bus/             # 消息总线├── session/         # 会话管理└── config/          # 配置管理

这个架构可以用一句话概括:Agent Loop是大脑,Tools是手脚,Memory是记忆,Skills是武器库,Providers是大脑的营养源。 接下来,让我们逐一拆解每个核心组件。

二、核心组件深度解析

2.1 Agent Loop —— 代理循环:整个系统的心脏

如果我们只能选择一个最重要的文件,那一定是loop.py。这个文件(约500行代码)包含了Agent的核心运行逻辑。让我带大家看看它的核心流程:

async def _run_agent_loop(self, initial_messages, on_progress=None):    """运行Agent迭代循环"""    messages = initial_messages    iteration = 0    while iteration < self.max_iterations:        iteration += 1        # 第一步:调用LLM获取响应        response = await self.provider.chat(            messages=messages,            tools=self.tools.get_definitions(),            model=self.model,            temperature=self.temperature,            max_tokens=self.max_tokens,        )        # 第二步:如果有工具调用,执行工具        if response.has_tool_calls:            # 添加助手消息(包含工具调用)            messages = self.context.add_assistant_message(...)            # 逐个执行工具调用            for tool_call in response.tool_calls:                result = await self.tools.execute(tool_call.name, tool_call.arguments)                messages = self.context.add_tool_result(messages, ...)        else:            # 没有工具调用,说明任务完成            final_content = response.content            break

这个流程有多聪明?它完美复现了人类思考问题的模式:“思考→行动→观察→再思考→再行动→...” 的循环。LLM负责思考和决策,工具负责执行具体操作,观察结果反馈给LLM,形成闭环。

更重要的是,这个循环是可中断的。用户随时可以输入/stop来终止当前任务,代码中有完善的取消机制:

if msg.content.strip().lower() == "/stop":    await self._handle_stop(msg)

这种设计让系统响应灵敏,用户体验极佳。

2.2 Context Builder —— 上下文构建:给LLM喂“合适”的信息

ContextBuilder(context.py)负责组装发送给LLM的完整上下文。这包括:系统提示词、历史消息、当前输入、内存内容、技能信息等。

它的核心方法build_messages构建了完整的消息列表:

def build_messages(self, history, current_message, media=None, channel=None, chat_id=None):    """构建完整的消息列表"""    # 1. 运行时上下文(时间、渠道等)    runtime_ctx = self._build_runtime_context(channel, chat_id)    # 2. 用户消息(可能包含图片)    user_content = self._build_user_content(current_message, media)    # 3. 合并所有内容    return [        {"role""system""content"self.build_system_prompt()},        *history,        {"role""user""content": merged},    ]

这里的系统提示词构建尤为精妙,采用渐进式加载策略:

def build_system_prompt(self, skill_names=None):    parts = [self._get_identity()]      # 核心身份    parts.append(self._load_bootstrap_files())  # 引导文件    parts.append(self.memory.get_memory_context())  # 记忆    parts.append(self.skills.load_skills_for_context(...))  # 常用技能    parts.append(self.skills.build_skills_summary())  # 技能概要    return "\n\n---\n\n".join(parts)

引导文件机制是nanobot的一个亮点。用户可以在工作区放置5个特殊的Markdown文件来自定义Agent行为:

  • AGENTS.md - Agent角色定义

  • SOUL.md - 核心价值观

  • USER.md - 用户信息

  • TOOLS.md - 工具说明

  • IDENTITY.md - 身份定义

这种设计让用户不需要修改代码,就能深度定制Agent的“性格”和能力。

2.3 Memory System —— 两层记忆体系:让Agent“记住”一切

nanobot的记忆系统(memory.py)采用经典的双层记忆架构

  1. 短期记忆:会话历史(Session Messages)

    • 存储在内存中

    • 保真度高,完整保留对话细节

    • 通过滑动窗口控制长度

  2. 长期记忆:两层存储

    • MEMORY.md - 长期事实记忆(重要信息)

    • HISTORY.md - 可搜索的历史日志

class MemoryStore:    """两层记忆:MEMORY.md(长期事实)+ HISTORY.md(可搜索日志)"""    def __init__(self, workspace):        self.memory_dir = ensure_dir(workspace / "memory")        self.memory_file = self.memory_dir / "MEMORY.md"        self.history_file = self.memory_dir / "HISTORY.md"

最令人称道的是自动记忆整合功能。当会话消息积累到一定数量(默认50条)时,系统会自动触发记忆整合:

async def consolidate(self, session, provider, model, archive_all=False, memory_window=50):    """将旧消息整合到MEMORY.md和HISTORY.md"""    # 1. 提取待整合的消息    old_messages = session.messages[session.last_consolidated:-keep_count]    # 2. 调用LLM进行总结    response = await provider.chat(        messages=[...],        tools=_SAVE_MEMORY_TOOL,  # 专门用于保存记忆的工具    )    # 3. LLM决定:哪些写入MEMORY,哪些写入HISTORY    if entry := args.get("history_entry"):        self.append_history(entry)  # 写入HISTORY.md    if update := args.get("memory_update"):        self.write_long_term(update)  # 更新MEMORY.md

这个设计太精妙了!它让LLM自己决定什么值得记住、什么可以遗忘,实现了自动化的信息过滤和结构化存储

2.4 Skills System —— 技能系统:按需加载的“武器库”

SkillsLoader(skills.py)实现了nanobot的技能系统。技能本质上是Markdown文件(SKILL.md),告诉Agent如何使用特定工具或完成特定任务。

渐进式加载是这里的核心智慧:

def build_system_prompt(self):    # 1. 常用技能:总是加载完整内容    always_skills = self.skills.get_always_skills()    always_content = self.skills.load_skills_for_context(always_skills)    # 2. 其他技能:只显示摘要    skills_summary = self.skills.build_skills_summary()    # Agent如果需要某个技能,会自己用read_file读取

技能可以来自两个地方:

  • 内置技能:项目自带的技能(如github、weather等)

  • 用户技能:用户在工作区skills/目录下自定义的技能

每个技能支持通过YAML Frontmatter声明元数据:

---name: githubdescription: GitHub操作技能always: false  # 是否总是加载requires:  bins: [gh]        # 需要的命令行工具  env: [GH_TOKEN]   # 需要的环境变量---

系统会自动检查依赖是否满足,未满足的技能会标记为available="false",并提示用户如何安装依赖。

2.5 Subagent Manager —— 子代理:并行处理复杂任务

当用户提出一个复杂任务时,主Agent可以“孵化”子代理(subagent.py)来并行处理:

async def spawn(self, task, label=None, origin_channel="cli", ...):    """孵化一个子代理来执行后台任务"""    task_id = str(uuid.uuid4())[:8]    # 创建后台任务    bg_task = asyncio.create_task(        self._run_subagent(task_id, task, display_label, origin)    )    # 立即返回,让主Agent可以继续响应用户    return f"Subagent [{display_label}] started (id: {task_id}). I'll notify you when it completes."

子代理拥有受限的工具集(只读文件、写入文件、执行Shell、搜索网页等),而且默认不能发送消息或孵化新的子代理,这体现了最小权限原则

子代理完成任务后,会通过消息总线将结果注入主Agent:

async def _announce_result(self, task_id, result, origin, status):    """通过消息总线宣布结果"""    msg = InboundMessage(        channel="system",        sender_id="subagent",        chat_id=f"{origin['channel']}:{origin['chat_id']}",        content=announce_content,    )    await self.bus.publish_inbound(msg)

这种设计让复杂任务可以后台异步执行,用户无需等待,极大提升了系统的响应能力。

2.6 Tool System —— 工具系统:Agent的“四肢”

nanobot的工具系统设计得非常优雅。采用注册制

class ToolRegistry:    def __init__(self):        self._tools: dict[str, Tool] = {}    def register(self, tool: Tool) -> None:        self._tools[tool.name] = tool    async def execute(self, name: str, params: dict) -> str:        tool = self._tools.get(name)        return await tool.execute(**params)

每个工具只需要继承Tool基类并实现三个属性和一个方法:

class Tool(ABC):    @property    @abstractmethod    def name(self) -> str:        pass  # 工具名称    @property    @abstractmethod    def description(self) -> str:        pass  # 工具描述(给LLM看)    @property    @abstractmethod    def parameters(self) -> dict:        pass  # JSON Schema参数定义    @abstractmethod    async def execute(self, **kwargs) -> str:        pass  # 执行逻辑

来看看一个具体工具长什么样(文件系统工具):

class ReadFileTool(Tool):    @property    def name(self) -> str:        return "read_file"    @property    def description(self) -> str:        return "Read content from a file..."    @property    def parameters(self) -> dict:        return {            "type""object",            "properties": {                "path": {"type""string""description""File path to read"},            },            "required": ["path"]        }    async def execute(self, path, **kwargs) -> str:        # 实际的文件读取逻辑        content = Path(path).read_text()        return content

nanobot内置的工具包括:

  • 文件系统:read_file, write_file, edit_file, list_dir

  • Shell执行:exec(执行命令行)

  • 网络:web_search, web_fetch

  • 消息:message(发送消息到各渠道)

  • 子代理:spawn(孵化子代理)

  • 定时任务:cron(定时执行)

  • MCP集成:mcp(Model Context Protocol)

2.7 Provider System —— LLM提供者:灵活的“大脑”选择

LLM Provider采用适配器模式,统一的抽象接口让切换不同的LLM变得轻而易举:

class LLMProvider(ABC):    @abstractmethod    async def chat(self, messages, tools=None, model=None, ...):        """发送聊天请求"""        pass    @abstractmethod    def get_default_model(self) -> str:        """获取默认模型"""        pass

nanobot支持的LLM提供者包括:

  • OpenRouter - 推荐,支持几乎所有主流模型

  • Anthropic - Claude直连

  • OpenAI - GPT直连

  • Groq - 高速推理 + Whisper语音转文字

  • Google Gemini - Gemini直连

  • vLLM - 本地模型支持

这种设计让用户可以根据需求(速度、成本、效果)灵活选择最适合的模型。

三、一次完整的对话流程

理解了各个组件,让我们把它们串起来,看看一次完整的对话是怎么处理的:

第一步:消息入口

用户通过CLI、Telegram、WhatsApp等渠道发送消息。消息被包装成InboundMessage,通过消息总线(bus)传递给Agent。

第二步:会话管理

Agent根据会话key获取或创建会话对象(Session),加载历史消息。

第三步:构建上下文

ContextBuilder组装系统提示词(包括身份、引导文件、记忆、技能概要)、历史消息和当前输入。

第四步:Agent循环

进入主循环:

  1. 调用LLM获取响应

  2. 如果有工具调用,执行工具,将结果返回给LLM

  3. 如果没有工具调用,说明任务完成

第五步:保存状态

  1. 将本次对话保存到会话历史

  2. 如果消息达到阈值,触发记忆整合

第六步:返回响应

通过消息总线将响应发送回用户所在的渠道。

整个流程如行云流水,每个组件各司其职,又紧密协作。

四、设计亮点总结

回顾nanobot的代码,有几个设计让我印象深刻:

1. 极简主义

4000行代码实现完整Agent功能,每个模块都恰到好处,不多不少。这体现了“少即是多”的哲学。

2. 模块化设计

每个组件职责单一,通过清晰接口交互。这种设计让代码易于理解,维护和扩展。

3. 渐进式加载

无论是技能还是记忆,都采用按需加载策略。这既控制了上下文长度,又保证了灵活性。

4. 自动化记忆

让LLM自己决定什么值得记住,实现了真正智能的信息管理。

5. 安全优先

子代理受限的工具集、严格的参数验证、沙箱限制执行,体现了安全设计思想。

6. 用户友好

引导文件机制让非开发者也能深度定制Agent行为,降低了使用门槛。

五、写在最后

nanobot是一个值得细细品味的项目。它用4000行代码诠释了什么是“优雅的复杂度”——表面上功能强大,背后的设计却简洁优美。

对于想学习Agent开发的工程师,我强烈建议阅读它的源码。你可以从loop.py入手,跟随代码走一遍完整流程,然后深入感兴趣的模块。这绝对是一次物超所值的技术之旅。

项目地址https://github.com/HKUDS/nanobot


如果你对nanobot或者AI Agent开发有什么问题,欢迎在评论区交流讨论。

「1 分钟上手」

# 1. 安装pip install nanobot-ai# 2. 初始化配置nanobot onboard# 3. 启动对话nanobot agent

其他相关分享:

OpenClaw:正在觉醒的AI超级生命体——26万星标背后的开源革命

Nanobot与OpenClaw对比分析

告别OpenClaw:43万行代码的负担,一个4000行的答案

拒绝“大模型焦虑”!这款超轻量级OpenClaw让你轻松玩转私有化部署

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-01 20:06:39 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/466964.html
  2. 运行时间 : 0.105878s [ 吞吐率:9.44req/s ] 内存消耗:5,040.90kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=92c320f84738b954f1d3463c5d6472ec
  1. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/composer/autoload_static.php ( 6.05 KB )
  7. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/ralouphie/getallheaders/src/getallheaders.php ( 1.60 KB )
  10. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  11. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  12. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  13. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  14. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  15. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  16. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  17. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  18. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  19. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/guzzlehttp/guzzle/src/functions_include.php ( 0.16 KB )
  21. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/guzzlehttp/guzzle/src/functions.php ( 5.54 KB )
  22. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  23. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  24. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  25. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/provider.php ( 0.19 KB )
  26. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  27. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  28. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  29. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/common.php ( 0.03 KB )
  30. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  32. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/alipay.php ( 3.59 KB )
  33. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  34. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/app.php ( 0.95 KB )
  35. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/cache.php ( 0.78 KB )
  36. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/console.php ( 0.23 KB )
  37. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/cookie.php ( 0.56 KB )
  38. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/database.php ( 2.48 KB )
  39. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/filesystem.php ( 0.61 KB )
  40. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/lang.php ( 0.91 KB )
  41. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/log.php ( 1.35 KB )
  42. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/middleware.php ( 0.19 KB )
  43. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/route.php ( 1.89 KB )
  44. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/session.php ( 0.57 KB )
  45. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/trace.php ( 0.34 KB )
  46. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/config/view.php ( 0.82 KB )
  47. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/event.php ( 0.25 KB )
  48. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  49. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/service.php ( 0.13 KB )
  50. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/AppService.php ( 0.26 KB )
  51. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  52. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  53. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  54. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  55. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  56. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/services.php ( 0.14 KB )
  57. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  58. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  59. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  60. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  61. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  62. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  63. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  64. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  65. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  66. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  67. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  68. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  69. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  70. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  71. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  72. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  73. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  74. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  75. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  76. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  77. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  78. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  79. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  80. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  81. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  82. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  83. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  84. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  85. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  86. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  87. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/Request.php ( 0.09 KB )
  88. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  89. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/middleware.php ( 0.25 KB )
  90. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  91. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  92. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  93. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  94. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  95. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  96. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  97. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  98. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  99. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  100. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  101. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  102. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  103. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/route/app.php ( 3.94 KB )
  104. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  105. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  106. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/controller/Index.php ( 9.87 KB )
  108. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/BaseController.php ( 2.05 KB )
  109. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  110. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  111. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  112. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  113. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  114. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  115. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  116. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  117. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  118. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  119. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  120. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  121. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  122. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  123. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  124. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  125. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  126. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  127. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  128. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  129. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  130. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  131. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  132. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  133. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  134. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  135. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/app/controller/Es.php ( 3.30 KB )
  136. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  137. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  138. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  139. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  140. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  141. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  142. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  143. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  144. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/runtime/temp/c935550e3e8a3a4c27dd94e439343fdf.php ( 31.80 KB )
  145. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000607s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000915s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000343s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000267s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000526s ]
  6. SELECT * FROM `set` [ RunTime:0.000207s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000538s ]
  8. SELECT * FROM `article` WHERE `id` = 466964 LIMIT 1 [ RunTime:0.000639s ]
  9. UPDATE `article` SET `lasttime` = 1775045199 WHERE `id` = 466964 [ RunTime:0.005169s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.000240s ]
  11. SELECT * FROM `article` WHERE `id` < 466964 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000534s ]
  12. SELECT * FROM `article` WHERE `id` > 466964 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000492s ]
  13. SELECT * FROM `article` WHERE `id` < 466964 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.006001s ]
  14. SELECT * FROM `article` WHERE `id` < 466964 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001761s ]
  15. SELECT * FROM `article` WHERE `id` < 466964 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001019s ]
0.107922s