当前位置:首页>Linux>Linux 启动十四 | 为什么你在 U-Boot 里改 bootargs,内核却从设备树里读?

Linux 启动十四 | 为什么你在 U-Boot 里改 bootargs,内核却从设备树里读?

  • 2026-06-29 22:39:02
Linux 启动十四 | 为什么你在 U-Boot 里改 bootargs,内核却从设备树里读?

很多人第一次看嵌入式 Linux 启动链,都会被一种很强的割裂感卡住。

明明前面在 U-Boot 里敲的是 setenv bootargs ...,到了内核里却变成了:

  • 内存大小

  • 串口节点

  • 中断控制器

  • /chosen/bootargs

  • stdout-path

更常见的是,明明改了 dts、重新编译了 dtb,结果内核读到的参数还是旧的。

  • 所以最典型的困惑通常就四个:

  • 设备树到底是谁传给内核的?

  • 内核为什么会认这份 dtb?

  • bootargs 到底写在 U-Boot 里还是设备树里?

  • /chosen/bootargs 又是怎么进去的?

一句话先讲明白。

设备树不是内核自己去找出来的,而是 bootloader 先把 dtb 准备好,再把它的地址交给内核;而 /chosen/bootargs 往往也是 bootloader 在启动内核前写进去的。

所以关键从来不是 dtb 文件存在哪。

关键是启动交接时,谁把哪份 dtb 传给了内核,以及启动前有没有改过它。

第一,设备树本质上是什么

设备树本质上是一份硬件描述数据。

它告诉内核:板子上有哪些硬件,内存在哪里,串口是谁,中断控制器是谁,设备挂在哪条总线上,以及某些关键启动参数放在哪。

也就是说,内核启动时并不是天然知道这块板子长什么样。

它需要别人把这份“硬件说明书”交给它。

这份说明书,在 ARM 和很多嵌入式平台里,通常就是 dtb。

设备树不是给 U-Boot 看的主配置文件,它更像给 Linux 内核看的硬件说明书。

第二,设备树是谁传给内核的

在大多数嵌入式 Linux 启动场景里,真正把设备树传给内核的,是 U-Boot。

常见流程很简单:U-Boot 先把 dtb 从存储介质读到内存,必要时做一些修改,最后在执行 bootibootmbootz时,把 dtb 地址一并交给内核。

所以内核并不是自己去某个分区、某个文件系统里找 dtb 文件。

它拿到的是 bootloader 已经准备好、并放到内存里的那一份设备树。

这点非常关键。

因为很多人排查设备树问题时,只盯着磁盘上的 dtb 文件,却忽略了真正传给内核的,可能已经不是那份原始文件了。

第三,为什么传给内核的 dtb 往往不是原封不动的

因为 U-Boot 在启动前,常常会改它。

最典型的就是 /chosen 节点。

很多平台在启动 Linux 前,U-Boot 会往 dtb 里补一些运行时信息,比如 bootargsstdout-path、initrd 起止地址、某些内存保留信息,以及板级运行时修正内容。

这意味着,编译出来的 dtb 只是一个基础模板,真正进内核前,它可能已经被 U-Boot patch 过了。

所以如果你看到内核里的某些设备树内容和源码里的 dts 不完全一样,先不要急着怀疑编译错误。

很有可能是 U-Boot 在交接前动态改过。

一个经典例子就是 memory 节点。

你在 dts 里可能写的是 1GB,但如果 bdinfo 里看到的内存大小和 dtb 里写的不一样,或者内核实际识别出来的内存大小又变了,也不用惊讶。

很多平台上,U-Boot 会根据自己的内存探测结果或板级修正,动态修改 dtb 里的 memory 节点。

所以真实链条往往是:U-Boot 先探测内存,再覆盖 dtb 里的 memory,最后内核再从这份 dtb 里读到内存大小。

第四,/chosen 节点到底是什么

如果你看过设备树源码,大概率见过这样的内容:

dts/chosen {    bootargs = "...";    stdout-path = "...";};

很多人第一次看会以为 /chosen 是某个硬件节点。

其实不是。

/chosen 更像一个启动交接专用节点。

它不是在描述某个外设,而是在告诉内核一些和“这次启动怎么接着往下走”相关的信息,比如 bootargsstdout-path、initrd 地址,以及某些启动期附加信息。

简单说,设备树里大部分节点是在描述硬件,/chosen 更像是在描述启动上下文。

第五,/chosen/bootargs 到底是怎么进去的

这是最常见、也最容易混的问题。

很多人看到 /chosen/bootargs 会问:这到底是写在 dts 里的,还是 U-Boot 的环境变量塞进去的?

答案是:

两种情况都可能,但现场最常见的是 U-Boot 在启动前把环境变量里的 bootargs 写进 /chosen/bootargs

常见路径通常是这样:

1. 你在 U-Boot 里有一个环境变量 bootargs

2. 这个字符串里写着 console=... root=... rootwait earlycon ...

3. U-Boot 在启动前把它写进 dtb 的 /chosen/bootargs

4. 内核启动时从 dtb 里读到它。

所以很多人表面上是在改 U-Boot 环境变量,实际最终效果是改了传给内核的设备树里的 /chosen/bootargs

这就是为什么你会感觉,明明是在 U-Boot 里 setenv bootargs,结果内核那边看到的是 /chosen/bootargs

如果再往底层看一步,这个过程通常会发生在 U-Boot 启动 Linux 之前:

  • 先把 dtb 加载到内存,

  • 再调用类似 fdt_chosen() 这样的接口去创建或更新 /chosen 节点,

  • 然后把环境变量 bootargs 的字符串写进去,

  • 最后再把这份 dtb 的地址连同内核一起交出去。

所以你在内核里看到的 /chosen/bootargs,本质上往往已经是 U-Boot 运行时环境变量的一份快照。

第六,为什么 dts 里有时也能看到 bootargs

因为设备树源码里本来也可以写死:

/chosen {    bootargs = "console=ttyS0,115200 root=/dev/mmcblk0p2 rw";};

这种做法不是不行,但在实际产品和调试里通常不够灵活。

因为启动参数经常会变:根文件系统位置会变,console 会变,可能要临时加 earlycon,启动介质也可能会换。

所以更常见的做法是:dts 里可以有默认值,但启动时由 U-Boot 用环境变量覆盖或更新。

也就是说,源码里的 bootargs 更像默认模板,真正生效的往往是 bootloader 改过后的结果。

第七,内核到底从哪里读取启动参数

很多人会把这几个来源混在一起:

  • U-Boot 环境变量 bootargs

  • 设备树里的 /chosen/bootargs

  • 以及最后看到的内核命令行。

其实把链条串起来就不难了:

  • U-Boot 里先有 bootargs

  • U-Boot 把它写进 dtb 的

     /chosen/bootargs

  • 内核启动时解析设备树,再从 /chosen/bootargs 里拿到命令行参数,

  • 最后这些参数变成后面看到的 kernel command line。

所以内核真正接手时,常见直接来源通常是 dtb 里的 /chosen/bootargs

而 U-Boot 环境变量,更多是它的上游来源。

一句更好记的话就是:

U-Boot 的 bootargs是“准备参数”,

/chosen/bootargs 是“交给内核的参数”。

第八,为什么这条链这么重要

因为很多启动问题,表面上看像内核问题,本质上其实是设备树交接问题。

最典型的现象就是:

  • console= 不对,导致你以为内核没输出;

  • root= 不对,导致根文件系统挂不上;

  • stdout-path 不对,导致控制台路径异常;

  • dtb 根本不是你以为那份,导致板级硬件描述不匹配。

这时候如果你只盯着内核镜像、rootfs 或某个驱动,很容易走偏。

因为真正该先确认的是:

U-Boot 到底加载了哪份 dtb,启动前有没有改/chosen,内核最终拿到的 bootargs 到底是什么。

很多“内核为什么这样启动”的问题,根子其实不在内核,而在 bootloader 交给它的设备树。

第九,工程上最该怎么记这件事

最稳的理解方式,不是把 dtb 看成一个静态文件,而是把它看成 bootloader 交给内核的一份启动期硬件描述和参数载体。

这里面最关键的两层要分开:

设备树主体节点主要描述硬件,

/chosen节点主要描述启动交接信息。

只要这个边界清楚,很多问题马上就顺了:

  • 为什么 dts 里没改,内核看到的却变了;

  • 为什么 setenv bootargs 会影响内核命令行;

  • 为什么串口输出问题常常要回头看 dtb 和 /chosen

  • 为什么 rootfs 问题有时也要回头看设备树传参。

最后把它压成两句话就够了。

Linux 启动时使用的设备树,通常是 U-Boot 先加载到内存,再在启动前把 bootargs等运行时信息写入 /chosen节点,最后把这份 dtb 的地址连同内核一起交给 Linux。

所以内核拿到的设备树,往往不是静态文件本身,而是 bootloader 处理后的结果。

怎么一句话记住

dtb 是 U-Boot 传给内核的,

/chosen/bootargs往往也是 U-Boot 写进去的。

所以下次当你遇到这些现象时,不要第一时间去怀疑内核或驱动:

  • 改了 U-Boot 的 bootargs,内核命令行没变;

  • 改了 dts 里的串口或内存,内核不认;

  • 根文件系统挂载失败,但路径看起来明明是对的。

更稳的判断方式只有一条:当你在内核里看到设备树内容时,先默认那是 U-Boot 加工后的“最终交付物”,而不是源码里的“原材料”。

最新文章

随机文章

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