乐于分享
好东西不私藏

第一次读 Claude Code 源码,别从最大的文件开始

第一次读 Claude Code 源码,别从最大的文件开始
很多人第一次打开 Claude Code 源码,会本能地做一件事:

先找最大的文件,觉得那里一定最重要。

这个直觉不算错,但很容易把人带偏。

因为 Claude Code 不是一个单点模块,而是一条任务链路。你如果一上来就扎进几千行的 main.tsx 或 REPL.tsx,很快会被命令参数、UI 状态、权限模式、MCP、插件、恢复会话这些细节淹没。

这篇文章想讲清楚一个判断:

读 Claude Code 源码,第一步不是找“最重要的文件”,而是先画出一次用户输入经过系统的路线图。

看完这一篇,你至少应该知道四个文件分别站在哪里:

cli.tsx -> main.tsx -> REPL.tsx -> query.ts

它们不是四个孤立文件,而是一条从“启动”到“执行”的主线。


一、为什么源码地图比逐行精读更重要

先给一个现实一点的事实。

在当前这份 Claude Code 源码里,这几个文件大概是这样的规模:

src/entrypoints/cli.tsx   约 401 行src/main.tsx              约 7049 行src/screens/REPL.tsx      约 6410 行src/query.ts              约 1775 行

如果你没有地图,直接打开 main.tsx,很容易产生两个错觉。

第一个错觉是:这个系统的核心就是 CLI 参数。

因为你会看到大量 Commander 配置、命令注册、模式判断、初始化逻辑。

第二个错觉是:这个系统的核心就是终端 UI。

因为你继续读 REPL.tsx,又会看到输入框、消息渲染、快捷键、状态同步、权限弹窗。

这些都重要,但它们不是主线。

主线应该是:

用户输入如何进入系统系统如何准备上下文和工具模型如何被调用工具结果如何回到 messages什么时候继续下一轮什么时候停止

也就是说,你不是在读一堆 TypeScript 文件。

你是在追踪一次 Agent turn 的生命周期。

源码地图的价值,不是告诉你文件名,而是告诉你先读什么、后读什么,以及每个文件在任务链路里负责哪一段。


二、先看 cli.tsx:它不是主角,但它决定你走哪条路

src/entrypoints/cli.tsx 是真正的入口。

但它的职责很克制:先判断有没有快速路径。

比如:

--version--dump-system-prompt--computer-use-mcp--daemon-workerremote-controldaemon

如果命中了这些路径,它就直接动态 import 对应模块,然后提前返回。

如果没有命中,才进入完整 CLI 主流程,也就是加载 main.tsx

你可以把 cli.tsx 理解成机场安检前的分流口:

只查版本的人,不需要进入候机大厅
启动 MCP server 的人,走专门通道
真正要进入交互式编程助手的人,才继续往里走

这解释了一个很关键的设计。

为什么 CLI 入口要这么薄?

因为启动速度很重要。

--version 这种命令如果也加载完整 React、工具系统、MCP、配置、权限,用户会明显感觉慢。Claude Code 把这些快速路径提前切走,本质上是在减少无意义模块加载。

所以读 cli.tsx 时,不要陷入每个分支的业务细节。

你只需要抓住一句话:

cli.tsx 负责决定这次启动是不是要进入完整 Agent 系统。


三、再看 main.tsx:它负责把“命令行程序”变成“会话”

如果 cli.tsx 是分流口,main.tsx 就是完整 CLI 的调度大厅。

这里会发生很多准备工作:

解析命令行参数注册子命令准备配置和认证加载工具和权限模式处理会话恢复准备 MCP 和插件决定进入 REPL 还是 headless 模式

这也是为什么 main.tsx 很长。

它不是因为“核心算法都在里面”,而是因为它承担了大量启动前的胶水工作。

读这个文件时,最容易犯的错是逐个子命令往下读。

比如你看到 mcpauthplugindoctordaemon,每个都想展开。这样读一天也很难形成主线。

更好的读法是只追一个问题:

普通交互式会话是怎么启动 REPL 的?

你会看到它最后会准备一批 initialMessagessessionConfiginitialState,然后调用类似 launchRepl(...) 的路径,把系统带到终端交互界面。

在这个阶段,Claude Code 还没有真正进入 Agent Loop。

它只是在做一件事:

把一个命令行启动,整理成一场可以继续对话、可以调用工具、可以保存状态的会话。

这一步很像开工前整理工位。

工具放哪里,权限怎么设,历史记录要不要恢复,当前目录是什么,模型用哪个,这些都要准备好。

否则后面的 query.ts 再强,也没有稳定的工作现场。


四、然后看 REPL.tsx:它不是输入框,而是用户和 Agent Loop 的桥

很多人看到 REPL.tsx,会以为它只是终端 UI。

这个理解太浅了。

REPL.tsx 确实负责输入框、消息展示、键盘交互、加载状态,但它更重要的职责是:

把用户输入变成 messages准备 systemPrompt / userContext / systemContext把 tools 和 permission 上下文交给 query消费 query 返回的事件用 setMessages 更新终端界面

这就不是普通 UI 了。

它是用户和 Agent Loop 之间的桥。

在源码里,你会看到类似这样的路径:

用户提交输入  ↓REPL 追加 user message  ↓准备 system prompt、上下文、工具、权限  ↓for await (const event of query(...))  ↓onQueryEvent(event)  ↓setMessages(...)

这里有一个很容易被忽略的点:REPL.tsx 不只是“展示模型输出”,它还要不断接收 query 里的流式事件。

比如 assistant 文本来了,要显示。

工具调用开始了,要显示。

工具结果回来了,要显示。

权限需要用户确认,也要在 UI 层接住。

所以读 REPL.tsx 时,不要把它当成普通 React 组件。

更准确的理解是:

REPL.tsx 负责把 Agent Loop 的内部事件,翻译成用户能看见、能操作、能打断的终端体验。


五、最后看 query.ts:这里才是 Agent turn 的心脏

到 query.ts,主线才真正进入 Agent Loop。

这个文件里有两个特别值得先抓住的点:

export async function* query(...)async function* queryLoop(...)

为什么是 async function*

因为它不是一次性返回最终答案,而是不断产出事件。

比如:

stream_request_startassistant messagetool_usetool_resultattachment最终 terminal reason

这正好对应我们前几篇讲过的模型:

messages -> model -> tool_use -> 本地工具 -> tool_result -> messages -> model

在 queryLoop 里,你会看到一个持续调度结构。

它每一轮大致做这些事:

准备 messagesForQuery请求模型并消费 streaming收集 assistantMessages识别 tool_use blocks执行 runTools(...)把 tool_result 转回可继续发送给模型的 user message合成下一轮 state.messages继续下一轮

这里最关键的不是某一行代码,而是状态如何流动。

尤其是这件事:

下一轮 messages = 上一轮 messages + assistantMessages + toolResults

如果这一步没发生,工具结果就不会进入下一轮模型推理。

这也是为什么我一直强调:tool_result 不是给用户看的日志,它是下一轮推理的燃料。

query.ts 的难点,不是它会调用模型,而是它要在流式输出、工具执行、上下文压缩、权限、停止条件之间维持一条不断裂的消息轨道。


六、这四个文件应该按什么顺序读

如果你是第一次读,我建议不要按文件大小读,也不要按 import 跳来跳去。

按这条路线读:

1. cli.tsx   只看启动分流:哪些路径会提前返回,什么时候进入 main.tsx2. main.tsx   只追交互式会话:参数、配置、工具、权限、session 如何准备,什么时候 launchRepl3. REPL.tsx   只追一次用户输入:输入如何进入 messages,query 如何被调用,事件如何更新 UI4. query.ts   只追一轮 Agent turn:模型如何返回 tool_use,工具如何执行,tool_result 如何回写,为什么继续下一轮

这条路线的好处是,你不会一开始就被工具实现、MCP、插件、远程控制、任务系统打散。

那些模块当然重要,但它们应该排在主线之后。

读源码最怕的是把支线当主线。

Claude Code 这种系统尤其如此。它有很多能力,但第一遍你只需要回答一个问题:

一句用户输入,是怎么一步步变成 Agent Loop 的?

只要这个问题通了,后面再读 Tool、Permission、MCP、Skills、Context、Memory,才不会散。


七、这一篇我们把源码地图也跑成 Demo

第五篇的代码不是重写一个新项目,而是在第四篇的基础上继续加。

上一章我们已经有:

messagesMockModelToolRegistryReadFileToolSearchFileToolAgentLoop

这一章新增一个教学工具:

SourceMapTool

它做的事很简单:当模型判断用户想要“Claude Code 源码地图”时,先返回一份源码地图文件路径:

src/main/resources/demo/ClaudeCodeSourceMap.md

然后 Agent Loop 继续调用 ReadFileTool 读取这份地图,最后由 MockModel 总结阅读顺序。

最小链路是:

UserMessage("帮我画一张 Claude Code 源码地图...")  ↓MockModel 返回 ToolUse(source_map, claude-code)  ↓SourceMapTool 返回 ClaudeCodeSourceMap.md  ↓MockModel 返回 ToolUse(read_file, ClaudeCodeSourceMap.md)  ↓ReadFileTool 读取源码地图  ↓MockModel 输出阅读建议

你会发现,这跟第四篇的结构完全一样。

变化的只是工具和任务。

这就是 Agent Harness 的一个重要特征:

主循环稳定以后,新增能力通常不是重写 Loop,而是新增工具、状态和模型可理解的任务协议。


本篇实践任务

Milestone:M01(005-008)
目标:让 Agent 基于源码地图工具,输出 Claude Code 的源码阅读路径。
代码地址:https://gitee.com/learn_java_together/mini-claude-code.git
当前分支:chapter/005-source-map
JDK 版本:17
输入:"帮我画一张 Claude Code 源码地图,告诉我 cli.tsx、main.tsx、REPL.tsx、query.ts 应该从哪里读起"
输出:终端打印三轮链路:源码地图工具 -> 读取源码地图 -> 最终阅读建议

运行方式:

git clone https://gitee.com/learn_java_together/mini-claude-code.gitcd mini-claude-codegit checkout chapter/005-source-mapmvn -q -DskipTests compile exec:java

你应该能看到类似链路:

loop step 1 -> source_maploop step 2 -> read_fileloop step 3 -> final answer

验收标准:

1
第一轮必须看到 source_map 的 tool_use 和 tool_result
2
第二轮必须看到 read_file 读取 ClaudeCodeSourceMap.md
3
第三轮必须输出 cli.tsx -> main.tsx -> REPL.tsx -> query.ts 的阅读顺序
4
messages 中必须保留用户输入、工具请求、工具结果和最终回答

失败注入:

mvn -q -DskipTests compile exec:java -Dexec.args="--max-steps=1"

这个命令会故意让 Agent 只跑一轮。

你要观察的是:系统是否能在拿到 source_map 结果后暂停,并保留中间 messages。

这能帮助你理解一个真实工程问题:

Agent 不只要能完成任务,也要能在任务未完成时留下可恢复、可调试的轨迹。


写在最后

如果只记住一句话:

读 Claude Code 源码,不要从文件大小开始,而要从一次用户输入的流向开始。

对第一次读源码的人,我建议下一步只做一件事:

把这四个文件按顺序打开,分别回答一个问题:

cli.tsx:这次启动走哪条路径?main.tsx:这次会话怎么准备?REPL.tsx:用户输入怎么进入 query?query.ts:tool_use 和 tool_result 怎么形成下一轮?

回答完这四个问题,你就已经建立了 Claude Code 的第一张源码地图。

下一篇,我们继续拆:

CLI 入口为什么这么薄:快速路径、动态 import、启动分流。

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-05-12 16:03:33 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/612720.html
  2. 运行时间 : 1.665162s [ 吞吐率:0.60req/s ] 内存消耗:4,744.83kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=a45a5a55f6fa9e3ebd3fb263b28afc55
  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.50 KB )
  145. /yingpanguazai/ssd/ssd1/www/wwww.yeyulingfeng.com/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000948s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001397s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.014828s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.016902s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001429s ]
  6. SELECT * FROM `set` [ RunTime:0.034004s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001659s ]
  8. SELECT * FROM `article` WHERE `id` = 612720 LIMIT 1 [ RunTime:0.085253s ]
  9. UPDATE `article` SET `lasttime` = 1778573014 WHERE `id` = 612720 [ RunTime:0.040812s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.029793s ]
  11. SELECT * FROM `article` WHERE `id` < 612720 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.017098s ]
  12. SELECT * FROM `article` WHERE `id` > 612720 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.056363s ]
  13. SELECT * FROM `article` WHERE `id` < 612720 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.170585s ]
  14. SELECT * FROM `article` WHERE `id` < 612720 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.519464s ]
  15. SELECT * FROM `article` WHERE `id` < 612720 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.488069s ]
1.671506s