乐于分享
好东西不私藏

OpenClaw技能动态加载机制详解

OpenClaw技能动态加载机制详解

有兴趣的朋友可以到我的知识星球“小龙虾孵化实验室”共同探索智能工具的实现与应用(落地与变现)。

目录

  1. 1. 核心概念
  2. 2. OpenClaw 技能加载机制
  3. 3. 小龙虾技能加载机制
  4. 4. 对比分析
  5. 5. 最佳实践
  6. 6. 故障排查

注:小龙虾是我开发的类OpenClaw系统


核心概念

什么是技能动态加载?

技能动态加载 = AI 启动时自动扫描技能目录,解析技能定义,生成工具列表,无需修改代码。

传统方式(静态)

// 硬编码在代码中this.toolDefinitions = [  { name'read_file', ... },  { name'write_file', ... },// 添加新技能需要修改代码];

动态加载

// 运行时生成this.toolDefinitions = this.loadSkillsFromDirectory();// 添加新技能只需复制文件到 skills/ 目录

技能文件格式(SKILL.md)

---name: weatherdescription: Get current weather and forecasts (no API key required).homepage: https://wttr.in/:helpmetadata: {"clawdbot":{"emoji":"🌤️","requires":{"bins":["curl"]}}}---# WeatherTwo free services, no API keys needed.## wttr.in (primary)```bashcurl -s "wttr.in/London?format=3"

Open-Meteo (fallback, JSON)

curl -s "https://api.open-meteo.com/v1/forecast?..."
**结构说明**:- **Frontmatter**(YAML):技能元数据  - `name` - 技能名称(工具调用名)  - `description` - 技能描述(AI 理解用途)  - `homepage` - 技能主页  - `metadata` - 扩展配置- **Markdown 正文**:技能使用说明、示例代码---## OpenClaw 技能加载机制### 目录结构~/.openclaw/├── workspace/│   └── skills/              # 技能目录│       ├── weather/         # 天气技能│       │   └── SKILL.md│       ├── stock-monitor/   # 股票监控│       │   └── SKILL.md│       └── README.md├── config/│   └── openclaw.json        # 配置文件└── ...

加载流程

┌─────────────────────────────────────────────────────────┐│ 1. OpenClaw Gateway 启动                                │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 2. 扫描 skills 目录                                      ││    for skill_dir in workspace/skills/                   ││      if exists(skill_dir + '/SKILL.md'):                ││        skills.append(parseSKILL(skill_dir))             │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 3. 解析 SKILL.md                                         ││    - 读取 frontmatter(YAML)                           ││    - 提取 name, description, metadata                   ││    - 验证技能格式                                        │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 4. 注册技能到工具系统                                   ││    tools.register({                                     ││      name: skill.name,                                  ││      description: skill.description,                    ││      handler: loadSkillHandler(skill.path)              ││    })                                                   │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 5. 生成系统提示词                                       ││    prompt = `                                           ││      你是阿财,老大的助手。                             ││                                                         ││      ## 你有以下工具                                     ││      ${tools.map(t => `- ${t.name}: ${t.description}`)}││                                                         ││      ...                                                ││    `                                                    │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 6. 发送给大模型                                         ││    - 大模型看到动态生成的工具列表                        ││    - 根据需要调用工具                                    ││    - Gateway 执行对应技能                                │└─────────────────────────────────────────────────────────┘

核心代码(伪代码)

// OpenClaw GatewayclassSkillManager {constructor(workspace) {this.skillsDir = path.join(workspace, 'skills');this.skills = [];  }asyncloadSkills() {// 扫描技能目录const dirs = await fs.readdir(this.skillsDir);for (const dir of dirs) {const skillPath = path.join(this.skillsDir, dir, 'SKILL.md');if (await fs.exists(skillPath)) {const skill = awaitthis.parseSKILL(skillPath);this.skills.push(skill);// 注册工具this.tools.register({name: skill.name,description: skill.description,handlerthis.createHandler(skill)        });      }    }  }asyncparseSKILL(path) {const content = await fs.readFile(path, 'utf-8');const parts = content.split('---');// 解析 YAML frontmatterconst frontmatter = yaml.parse(parts[1]);return {name: frontmatter.name,description: frontmatter.description,path: path,body: parts[2]    };  }buildPrompt() {const lines = ['## 你有以下工具'];for (const skill ofthis.skills) {      lines.push(`- ${skill.name}${skill.description}`);    }return lines.join('\n');  }}

特点

特性
说明
技能存储~/.openclaw/workspace/skills/
加载时机
Gateway 启动时
技能格式
SKILL.md(YAML frontmatter + Markdown)
工具注册
自动注册到 Gateway 工具系统
提示词生成
运行时动态生成
技能执行
Gateway 统一调度

小龙虾技能加载机制

目录结构

simple-ai/├── src/│   ├── core/│   │   ├── skill_loader.py      # 技能加载器│   │   └── plugin_manager.py    # 插件管理器│   └── assistant-v7.js          # AI 核心├── skills/                      # 技能目录(与 OpenClaw 共享)│   └── weather/│       └── SKILL.md└── ...

加载流程

┌─────────────────────────────────────────────────────────┐│ 1. 小龙虾启动(node src/server.js)                  │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 2. 创建 AI 助手实例                                      ││    const assistant = new SimpleAIAssistant(...)         │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 3. 调用异步初始化                                        ││    await assistant.init()                               │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 4. 加载技能(调用 Python 加载器)                        ││    spawn('python', ['skill_loader.py', skills_dir])    │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 5. Python 技能加载器执行                                 ││    - 扫描 skills 目录                                    ││    - 解析 SKILL.md                                       ││    - 输出技能列表(JSON/文本)                          │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 6. Node.js 解析输出                                     ││    - 提取技能名和描述                                    ││    - 构建工具定义(JSON Schema)                       ││    - 更新 this.toolDefinitions                          │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 7. 生成系统提示词                                       ││    this.buildToolsPrompt()                              │└─────────────────────────────────────────────────────────┘                          ↓┌─────────────────────────────────────────────────────────┐│ 8. 调用大模型 API                                        ││    - 发送工具定义给千问 API                              ││    - 接收工具调用请求                                    ││    - 执行对应技能                                        │└─────────────────────────────────────────────────────────┘

核心代码

Python 技能加载器(skill_loader.py)

classSkillLoader:def__init__(self, skills_dir):self.skills_dir = skills_dirself.skills = []defscan_skills(self):"""扫描所有技能"""for item in os.listdir(self.skills_dir):            item_path = os.path.join(self.skills_dir, item)ifnot os.path.isdir(item_path) or item.startswith('.'):continue            skill_md = os.path.join(item_path, 'SKILL.md')if os.path.exists(skill_md):                skill = self._parse_skill_md(skill_md)if skill:self.skills.append(skill)print(f"[OK] 加载技能:{skill['name']}")returnself.skillsdef_parse_skill_md(self, path):"""解析 SKILL.md"""withopen(path, 'r', encoding='utf-8'as f:            content = f.read()# 提取 frontmatterif content.startswith('---'):            parts = content.split('---'2)            frontmatter_str = parts[1].strip()            frontmatter = self._parse_yaml(frontmatter_str)return {'name': frontmatter.get('name'''),'description': frontmatter.get('description'''),'path': path,            }returnNonedefbuild_tools_definition(self):"""构建工具定义(JSON Schema)"""        tools = []for skill inself.skills:            tool = {'type''function','function': {'name': skill['name'],'description': skill['description'],'parameters': {'type''object','properties': {'city': {'type''string','description''城市名','default''Beijing'                            }                        }                    }                }            }            tools.append(tool)return tools

Node.js AI 核心(assistant-v7.js)

classSimpleAIAssistant {constructor(apiKey, workspace) {this.workspace = workspace;this.skillsDir = path.join(workspace, '..''skills');this.skills = [];this.toolDefinitions = [];  }asyncinit() {awaitthis.loadSkills();awaitthis.loadMemoryToCache();  }asyncloadSkills() {log('正在加载技能...');// 调用 Python 技能加载器const result = awaitnewPromise((resolve, reject) => {const pyProcess = spawn('python', [        path.join(__dirname, 'core''skill_loader.py'),this.skillsDir      ], {cwdthis.workspace,encoding'utf-8'      });let output = '';      pyProcess.stdout.on('data'(data) => { output += data; });      pyProcess.on('close'(code) => {if (code === 0resolve(output);elsereject(newError('加载失败'));      });    });// 解析输出,提取技能const skillMatches = result.match(/\[OK\] 加载技能:(.+)/g);if (skillMatches) {for (const match of skillMatches) {const skillName = match.replace('[OK] 加载技能:''').trim();this.skills.push({ name: skillName });      }    }// 更新工具定义this.toolDefinitions = this.buildToolDefinitions();log(`加载完成:${this.skills.length} 个技能`);  }buildToolDefinitions() {// 基础工具const baseTools = this.getBaseToolDefinitions();// 技能工具const skillTools = this.skills.map(skill => ({type'function',function: {name: skill.name,description`调用${skill.name}技能`,parameters: {type'object',properties: {city: {type'string',description'城市名',default'Beijing'            }          }        }      }    }));return baseTools.concat(skillTools);  }buildToolsPrompt() {const lines = ['## 你有以下工具'];// 基础工具const baseTools = this.getBaseToolDefinitions();for (const tool of baseTools) {      lines.push(`- ${tool.function.name}${tool.function.description}`);    }// 技能工具for (const skill ofthis.skills) {      lines.push(`- ${skill.name}: 调用${skill.name}技能`);    }return lines.join('\n');  }}

特点

特性
说明
技能存储simple-ai/../skills/
(可与 OpenClaw 共享)
加载时机
AI 启动时(异步)
技能格式
SKILL.md(与 OpenClaw 兼容)
工具注册
动态生成 JSON Schema
提示词生成
运行时动态生成
技能执行
Node.js 直接执行或调用 Python

📊 对比分析

架构对比

维度
OpenClaw
小龙虾
运行环境
Node.js Gateway
Node.js + Python
技能目录~/.openclaw/workspace/skills/simple-ai/../skills/
加载方式
直接扫描
调用 Python 加载器
工具注册
Gateway 内部注册
JSON Schema 生成
技能执行
Gateway 统一调度
直接执行/Python 调用
配置复杂度
中等
简单

优劣势分析

OpenClaw

优势

  • • 统一调度,资源管理好
  • • 技能执行环境隔离
  • • 支持复杂技能编排
  • • 有完整的技能市场

劣势

  • • 架构复杂,学习成本高
  • • 需要 Gateway 常驻运行
  • • 技能执行有额外开销

小龙虾

优势

  • • 架构简单,易于理解
  • • 直接执行,响应快
  • • Python + Node.js 灵活组合
  • • 可与 OpenClaw 共享技能

劣势

  • • 技能执行需要自己管理
  • • 没有统一的调度系统
  • • 技能市场依赖 OpenClaw

【注:现已接入腾讯的skills社区】


实践

1. 技能目录管理

推荐结构

skills/├── weather/              # 按功能分类│   └── SKILL.md├── stock-monitor/│   └── SKILL.md└── README.md             # 技能说明文档

命名规范

  • • 技能名用小写字母和连字符
  • • 避免中文和空格
  • • 描述要清晰简洁

2. SKILL.md 编写

好的示例

---name: weatherdescription: 查询全球任何城市的当前天气和预报homepage: https://wttr.in/metadata: {"emoji":"🌤️"}---# Weather Skill查询天气情况,无需 API 密钥。## 使用方法```bashcurl -s "wttr.in/Beijing?format=3"

参数说明

  • • city: 城市名(英文或拼音)
  • • format: 输出格式(3=简洁,T=详细)
**避免**:- 描述过于简单("查天气")- 没有使用示例- 参数说明不清晰### 3. 技能加载优化**启动时预加载**:```javascript// 推荐:启动时加载await assistant.init();// 不推荐:每次请求都加载async chat() {  await this.loadSkills();  // 太慢!}

缓存技能列表

# 技能变化时重新加载if skills_changed:    loader.scan_skills()else:return cached_skills

4. 错误处理

技能加载失败

try {awaitthis.loadSkills();catch (error) {log(`技能加载失败:${error.message}`);// 使用基础工具继续运行this.toolDefinitions = this.getBaseToolDefinitions();}

技能执行失败

asyncexecuteSkill(skill, params) {try {returnawait skill.handler(params);  } catch (error) {return`技能执行失败:${error.message}`;  }}

🔧 故障排查

问题 1:技能未加载

现象:AI 说"我没有这个工具"

排查步骤

  1. 1. 检查技能目录是否存在
    ls ~/.openclaw/workspace/skills/
  2. 2. 检查 SKILL.md 格式
    cat weather/SKILL.md
  3. 3. 查看加载日志
    tail -f logs/info.log | grep "技能"
  4. 4. 手动测试加载器
    python src/core/skill_loader.py ~/.openclaw/workspace/skills/

问题 2:技能加载报错

常见错误

  • • output is not defined → Promise 作用域问题
  • • EADDRINUSE → 端口被占用
  • • ENOENT → 文件路径错误

解决方法

  1. 1. 检查代码中的变量作用域
  2. 2. 停止占用的进程
  3. 3. 使用绝对路径

问题 3:技能执行失败

排查步骤

  1. 1. 检查技能依赖(如 curl、python 包)
  2. 2. 查看技能执行日志
  3. 3. 手动测试技能命令
  4. 4. 检查权限问题

总结

核心要点

  1. 1. 技能即文件 - 每个技能是独立的 SKILL.md 文件
  2. 2. 动态发现 - 启动时自动扫描,无需修改代码
  3. 3. 提示词生成 - 运行时构建工具列表
  4. 4. 零配置 - 用户安装技能后重启即可用

计划

  1. 1. 技能热加载 - 无需重启即可加载新技能
  2. 2. 技能依赖管理 - 自动安装技能依赖
  3. 3. 技能沙箱 - 更安全地执行第三方技能
  4. 4. 技能市场 - 一键安装社区技能
  5. 有兴趣的朋友可以到我的知识星球“小龙虾孵化实验室”共同探索智能工具的实现与应用(落地与变现)。

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-03-24 01:06:13 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/483698.html
  2. 运行时间 : 0.107855s [ 吞吐率:9.27req/s ] 内存消耗:4,722.07kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=754fb6240d8746ad88d112cd60b8d308
  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.68 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.000609s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000978s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000384s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000319s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000580s ]
  6. SELECT * FROM `set` [ RunTime:0.000231s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000655s ]
  8. SELECT * FROM `article` WHERE `id` = 483698 LIMIT 1 [ RunTime:0.004430s ]
  9. UPDATE `article` SET `lasttime` = 1774285573 WHERE `id` = 483698 [ RunTime:0.010790s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.000279s ]
  11. SELECT * FROM `article` WHERE `id` < 483698 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000477s ]
  12. SELECT * FROM `article` WHERE `id` > 483698 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000426s ]
  13. SELECT * FROM `article` WHERE `id` < 483698 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001591s ]
  14. SELECT * FROM `article` WHERE `id` < 483698 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.003521s ]
  15. SELECT * FROM `article` WHERE `id` < 483698 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001184s ]
0.109646s