乐于分享
好东西不私藏

OpenClaw 火了,我花三天拆透了它的架构

OpenClaw 火了,我花三天拆透了它的架构

为什么要研究 OpenClaw 的架构?

最近 OpenClaw 在开发者社区里突然热了起来。

GitHub Star 数在短时间内快速增长,各个技术群里开始频繁出现它的名字,有人说「终于找到一个能在生产跑的 Agent 框架」,有人在分享自己用它接 Telegram、飞书、Discord 的经验,还有人直接把它部署在家里的 NAS 上当私人助理用。

我起初没太在意——AI Agent 框架这两年多如牛毛,大多数不是过度封装就是停留在 Demo 阶段。

但看到越来越多人认真在用,而不只是 Star 完就走,好奇心上来了:这东西到底哪里不一样?

于是我花了几天时间认真把它的架构拆了一遍。结论是:它火,是有道理的。

OpenClaw(也叫 ClawdBot)是一个开源的 AI Agent 运行时框架,跑在 Node.js 22+ 上,TypeScript ESM 编写。它的价值不在于「又封装了一层 LLM」,而在于它把多用户并发、上下文管理、记忆系统、工具执行这些工程问题,用一套清晰的架构设计逐一解掉了——而且解得相当漂亮。

这篇文章,我带你完整拆一遍它的架构——从顶层设计到每个环节的运行机制。


一、整体架构:像操作系统的微内核

先建立一个直觉——OpenClaw 的整体架构,设计灵感类似操作系统的微内核

它采用四层逻辑架构

图片由AI生成,供参考,曾在某视频号看到下图,亦可帮助理解。

网关层(Gateway)      —— 神经中枢 / 控制平面渠道层(Channels)     —— 感官系统 / 感知层智能体层(Agent)      —— 大脑     / 决策层技能层(Skills/Tools) —— 执行系统 / 行动层

这四层的职责划分极其清晰:感知、路由、决策、执行,各司其职,互相解耦。任何一层出了问题,都能快速定位,不会相互污染。

一条消息从进来到处理完毕,完整走下来,就像一次神经反射回路——从感知到行动,形成闭环。


二、渠道层:感官系统

职责:把外部世界的消息,变成 OpenClaw 能处理的标准格式。

OpenClaw 支持接入的平台包括:Telegram、WhatsApp、Discord、飞书、Teams、微信、Web UI、CLI……每个平台的消息协议都不一样。

渠道适配器做两件事:

  1. 1. 消息标准化:把不同平台的原始消息结构,统一转换成内部指令格式
  2. 2. 提取附件:图片、语音、文件,统一处理后交给后续流程

每个适配器独立运行,某个渠道挂了,不影响其他渠道,也不影响 Gateway 主循环。这种故障隔离是架构层面保证的,不是靠业务代码小心翼翼地 try-catch 实现的。


三、网关层:整个系统的神经中枢

职责:整个系统的调度核心,所有消息必须经过这里。

Gateway 是 OpenClaw 里设计最精密的一层,有几个细节值得单独展开说。

它在哪里运行?

Gateway 是一个 24/7 持久化 WebSocket RPC 服务器,默认运行在本机 127.0.0.1:18789(回环地址)。

默认只接受本机连接。如果要从远程接入,需要走 SSH 隧道或 Tailscale,配合 Token 认证和设备配对机制——安全边界清晰,不会暴露在公网。

Session Key:并发控制的枢纽

消息进来之后,Gateway 要做一件核心事:生成 Session Key

格式长这样:

agent:<agentId>:<channel>:<type>:<identifier># 示例:agent:main:telegram:direct:+8613800138000

这个 Key 完整编码了「谁在说话」「从哪个渠道来」「是什么对话类型」。不需要额外维护一张状态表,一个 Key 就是完整的上下文定位符。

车道队列:多用户并发的精妙解法

生成 Session Key 之后,消息进入车道队列(Lane Queue)

这是 OpenClaw 里我觉得设计最克制的部分:

  • • 同一个 Session Key 的消息:串行处理,进同一条「车道」,先来先处理,不乱序
  • • 不同 Session Key 之间:并行执行,互不干扰
  • • 全局并发上限:防止 LLM 并发调用量失控

整套实现是纯 TypeScript + Promise,没有 Redis,没有消息队列中间件,就是几十行代码。它解决的是「多用户并发 + 单用户串行」这个经典矛盾,用的方式极其简单直接。


四、智能体层:大脑

职责:在当前 Session 真正「开始想」之前,把所有上下文准备好;然后驱动 LLM 完成决策。

Agent Runner 内部有三个核心组件。

模型解析器

根据配置和当前任务类型,决定用哪个 LLM。支持 Anthropic、OpenAI、Google Gemini、本地模型,并内置 Failover 降级链——主模型不可用时,自动切换备用模型,上层业务无感知。

System Prompt 构建器:Agent 的「人格装配线」

buildAgentSystemPrompt 按固定顺序,把以下内容逐段注入:

顺序
内容
来源
1
操作指令 + 记忆规则
AGENTS.md
2
人格 · 边界 · 语调
SOUL.md
3
工具使用指南
TOOLS.md
4
Agent 身份
IDENTITY.md
5
用户资料
USER.md
6
一次性初始化
BOOTSTRAP.md
(用完即删)
7
当前可用技能包
Skills XML 列表
8历史记忆召回SQLite 混合搜索
9
工具函数签名
内置 + 插件工具
10
运行环境信息
时间 · 平台 · 版本

第 8 条值得重点说:每次执行前,OpenClaw 会用混合搜索(向量搜索 0.7 权重 + FTS5 关键词搜索 0.3 权重)从本地 SQLite 记忆库里召回最相关的历史内容,注入当前上下文。这是 Agent 能「记住事情」的根本机制。

为什么用 Markdown 文件而不是 JSON/YAML?因为 LLM 天然读写 Markdown。把各部分拆成独立文件,LLM 可以直接用工具读写自己的「配置」,可读性和可维护性远好于一个大 JSON blob。

上下文窗口护栏

当上下文长度接近模型的 Token 上限时,护栏触发记忆刷写(Memory Flush):在正常对话之间插入一次「无声 turn」,先把当前上下文里的重要信息写入记忆库,再对历史对话做压缩处理。全程对用户透明。

很多框架遇到 Context Window 快满的时候,直接截断历史——信息白白丢掉。OpenClaw 选择先归档、再压缩。


五、完整的运行闭环:一条消息的旅程

把四层串起来,看一条消息从进来到回复的完整过程:

① 消息入口用户通过聊天应用输入指令(比如「帮我搜一下最新 AI 论文」)。渠道适配器捕获消息,转换为标准化的内部指令格式。

② 网关路由Gateway 验证消息来源是否合法,生成 Session Key,将消息放入对应的车道队列,路由给对应的 Agent 处理。

③ 智能体决策Agent 加载当前会话的上下文(历史记录 + 记忆召回),组装 Prompt,发送给 LLM。LLM 返回结构化指令或可执行代码。

④ 技能执行(Agentic Loop)

LLM 响应回来之后,OpenClaw 不会直接把结果返回给用户,而是先判断:

LLM 回复 → 调用工具吗?    │    ├─── 是 → 执行工具 → 把结果返回给 LLM → 继续下一轮 loop    │    └─── 否 → 生成最终回复文本 → 进入回复路径

这是标准的 ReAct 模式:先推理(Reason),再行动(Act),行动结果再喂回给 LLM,循环下去,直到 LLM 认为任务完成为止(响应中不再包含 tool_use block)。

OpenClaw 内置了两类工具:

  • • 核心工具read / write / edit(文件操作)、exec(执行系统进程)
  • • 扩展工具browser(浏览器自动化)、memory_search(记忆检索)、web_fetch / web_search(网络)、canvas(界面渲染)、cron(定时任务)

插件可以注册自定义工具,onToolCall Hook 可以在执行前做拦截——比如危险操作需要人工确认,直接在这里加逻辑。

⑤ 响应反馈Agentic Loop 输出最终文本,通过渠道层发回聊天应用。支持流式返回,LLM 每生成一段,立刻推送出去,用户看到的是逐字出现。Gateway 同步通过 WebSocket 广播给所有订阅方(如 Web 管理面板),全程可观测。


六、记忆系统:Agent 的「长期记忆」

记忆系统贯穿整个流程,单独展开说。

OpenClaw 的记忆分两层:

  • • MEMORY.md:策展式长期记忆,由 Agent 自主判断哪些信息值得写入,是精华
  • • memory/YYYY-MM-DD.md:每日流水日志,append-only,不做归纳

底层全部存在 SQLite~/.openclaw/memory/<agentId>.sqlite),两种索引:

  • • 向量搜索:通过 sqlite-vec 扩展,支持本地 GGUF 模型做 Embedding,不依赖云端服务
  • • FTS5 全文搜索:SQLite 内置,关键词精确匹配

召回时加权合并:向量 0.7,FTS5 0.3。语义相关优先,兼顾关键词命中。

Embedding 的降级链:本地 GGUF → OpenAI → Gemini → Voyage → 彻底禁用向量功能。在没有网络或不想用云端 Embedding 的情况下,可以跑纯本地。


七、包结构速览

目录
职责
src/agents/
Agent 运行时核心总入口
src/agents/pi-embedded-runner/
Agentic Loop 主循环
src/agents/system-prompt.ts
System Prompt 分段组装
src/agents/model-selection.ts
模型选择与 Failover 降级链
src/memory/
记忆系统(SQLite + 向量 + FTS5)
src/routing/
消息路由与 Session Key 生成
src/hooks/
Hook 生命周期系统
src/cron/
定时任务调度
src/browser/
浏览器自动化控制层
src/telegram/src/discord/
 …
各平台渠道适配器
extensions/
插件扩展目录(MSTeams、Matrix、Zalo 等)

依赖方向单向:Channel → Gateway → Agent Runtime。Agent Runtime 对上层一无所知,可以单独抽出来用,不绑定任何渠道。未来替换 Agent 引擎,只改 pi-embedded-runner 这一层,其余模块不动。


八、几点观察

车道队列那几十行代码,解决的是个经典难题。 多用户并发 + 单用户串行,如果上 Redis + 消息队列,运维成本一下就上来了。OpenClaw 用纯 Promise 实现,没有外部依赖,放在生产里跑完全没问题。技术选型的克制,往往比选「最先进」的方案更难。

Gateway 的安全边界设计得很干净。 默认只监听回环地址,外部接入强制走 SSH 隧道或 Tailscale,不会不小心暴露在公网。这种「默认安全」的设计思路,比「功能优先、安全靠后」靠谱得多。

Markdown 作为 LLM-Native 接口,确实比 JSON 好用。SOUL.md、IDENTITY.md、USER.md 这些文件,LLM 直接读得懂,也可以用工具直接写。这个思路在做 Agent 系统时值得借鉴——把 LLM 的配置和记忆设计成它自己能读写的格式。

五个环节,边界清晰到几乎一眼就能定位问题在哪层。 消息没到 Agent?查 Gateway。上下文组装不对?查 system-prompt.ts。工具没执行?查 Agentic Loop 的 onToolCall Hook。这种可观测性,在做了几个月维护之后,你会懂得有多值钱。


如果你要深入看源码

推荐从这几个文件入手:

  • • src/agents/pi-embedded-runner/run.ts — Agentic Loop 核心
  • • src/routing/resolve-route.ts — 路由解析与 Session Key 生成
  • • src/agents/system-prompt.ts — System Prompt 组装逻辑
  • • src/gateway/server.impl.ts — Gateway 主服务入口

看完这四个文件,一条消息从进来到回复的整条链路,在脑子里就能跑通了。


觉得有用的话,转给同样在做 AI Agent 的朋友。有问题或者你也在研究这块,评论区见。


本文技术内容基于 OpenClaw 开源仓库及官方架构文档,截至 2026 年 4 月。

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-05 14:20:18 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/499144.html
  2. 运行时间 : 0.089627s [ 吞吐率:11.16req/s ] 内存消耗:4,730.30kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=e2992464f159c8c8455b5d64f3248c5a
  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.000536s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000819s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000433s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000261s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000543s ]
  6. SELECT * FROM `set` [ RunTime:0.000198s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000641s ]
  8. SELECT * FROM `article` WHERE `id` = 499144 LIMIT 1 [ RunTime:0.000736s ]
  9. UPDATE `article` SET `lasttime` = 1775370018 WHERE `id` = 499144 [ RunTime:0.003948s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.000232s ]
  11. SELECT * FROM `article` WHERE `id` < 499144 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000406s ]
  12. SELECT * FROM `article` WHERE `id` > 499144 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.001105s ]
  13. SELECT * FROM `article` WHERE `id` < 499144 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001892s ]
  14. SELECT * FROM `article` WHERE `id` < 499144 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001054s ]
  15. SELECT * FROM `article` WHERE `id` < 499144 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.000834s ]
0.091379s