当前位置:首页>Linux>从0开始理解Linux内核并发:多核时代的生存法则

从0开始理解Linux内核并发:多核时代的生存法则

  • 2026-07-02 00:29:39
从0开始理解Linux内核并发:多核时代的生存法则

从0开始理解Linux内核并发:多核时代的生存法则

仓库已经开源!所有教程,主线内核移植,跑新版本imx-linux/uboot都在这里,或者一起来尝试跑7.0的Linux!欢迎各位大佬观摩!喜欢的话点个⭐!

仓库地址:https://github.com/Awesome-Embedded-Learning-Studio/imx-forge

静态网页:https://awesome-embedded-learning-studio.github.io/imx-forge/

前言:为什么这个问题在2026年比以往任何时候都重要

老实说,当我第一次在代码里遇到并发bug的时候,我是真的懵了。

不是因为代码有多难理解——那只是几个全局变量和一个简单的计数器——而是因为这个问题完全不可复现。开发环境跑得好好的,到了用户手里就莫名其妙崩溃;调试了一百次都没问题,第一百零一次,因为timing的微小差异,系统崩了。

这类bug最折磨人的地方在于它的「幽灵性」。你调了一整天,什么都查不出来,准备下班的时候,它又出现了。你开始怀疑人生,怀疑CPU,甚至怀疑是不是量子力学在作祟。

但当你真正理解了并发之后,你会发现这一切都有迹可循。而且,在2026年的今天,这个问题比以往任何时候都重要——因为单核时代已经彻底结束了

我们现在面对的ARM SoC,双核、四核甚至八核都是标配。i.MX6ULL虽然是2016年的芯片,但也是双核Cortex-A7。多核意味着什么?意味着真正的物理并行,意味着你的代码可能在Core 0上跑的同时,另一个线程在Core 1上跑。它们是同时执行的,不是轮流切换的。

这就导致了一个残酷的现实:你在单核思维里显而易见的「顺序」,在多核系统的现实中根本不存在。

环境:我们在这片土地上耕作

在开始之前,先说明一下我们的环境:

项目
版本/信息
内核版本
Linux 7.0-rc4 (主线内核)
架构
ARMv7-A (Cortex-A7 dual-core)
工具链
arm-none-linux-gnueabihf-gcc
开发板
i.MX6ULL (正点原子Alpha板)
特殊约束
SMP启用,内核抢占启用

这个配置很重要,因为并发问题的表现形式会根据配置不同而变化。比如在单核非抢占内核上,某些竞争条件可能永远不会出现;但在我们的双核抢占式内核上,它们就是家常便饭。

并发的四大源头:到底是谁在捣乱

我们要做的第一件事,就是搞清楚「并发」到底从哪里来。很多初学者以为并发就是「多线程」,其实在Linux内核里,并发来源要复杂得多。

来源一:多线程并发访问

这是最基本、最容易理解的。Linux是贪婪的多任务系统,多个进程/线程本来就在竞争CPU。如果你的驱动被多个进程打开,它们可能同时进入你的readwrite函数。

/* 两个进程同时打开同一个设备 */
$ cat /dev/mydevice &  /* 进程A */
$ cat /dev/mydevice &  /* 进程B */

这两个进程可能同时在不同的CPU核心上执行mydevice_read()函数。如果它们操作同一个全局变量,那就完了。

来源二:抢占式并发访问

从2.6版本内核开始,Linux内核是可抢占的。这意味着什么?意味着你的内核代码正在运行时,调度器可能会突然说:「停,你太慢了,换别人跑。」然后把你强行换下CPU。

/* 你正在执行这个函数 */
voidmy_function(void) {
    global_counter++;  /* 刚执行完这一行 */

/* ← 调度器突然把你切走了! */

    global_counter *= 2;  /* 等你回来的时候,global_counter已经被别人改了 */
}

等你恢复运行时,全局变量已经被别人改了。这叫「上下文切换导致的竞争」。

来源三:中断程序并发访问

中断的优先级很高。无论你的代码执行到哪一步,一旦硬件中断来了,CPU必须立刻响应。

voidmy_function(void) {
    spin_lock(&lock);  /* 获取锁 */

/* ← 硬件中断发生!CPU跳转到ISR执行 */

/* 中断服务程序ISR */
voidirq_handler(void) {
        spin_lock(&lock);  /* 试图获取同一把锁...死锁! */
    }

    spin_unlock(&lock);
}

中断说:「你先把锁放开我才能干活。」 线程说:「你把CPU还给我,让我跑完,我就能放开锁。」 互相指着鼻子,谁也动不了。这就是死锁

来源四:SMP(多核)核间并发访问

现在的ARM处理器,双核、四核甚至八核都很常见。如果是多核CPU,情况就更糟了。

/* Core 0 上执行 */
voidcore0_function(void) {
    global_var = 10;
}

/* 同时,Core 1 上执行 */
voidcore1_function(void) {
    global_var = 20;
}

这两个函数是真正物理意义上的「同时」执行。即使关掉内核抢占,两个核心依然可以同时读写同一块内存。这是最难以调试的并发问题,因为你无法通过单步调试来重现它——单步调试时,时间被拉长了,竞争条件消失了。

我们到底在保护什么?

前面一直在说「防止并发访问」、「防止竞争」,听起来像是在守卫一座城堡。那么问题来了:城堡里到底有什么?

我们需要保护的内容,是数据

一定要记住:我们保护的不是代码,而是数据。

某个线程的局部变量是不需要保护的。为什么?因为局部变量存在栈上,每个线程都有自己的私有栈,互不干扰。你改你的,我改我的,井水不犯河水。

我们要保护的,是那些多个执行流都能看到、摸到的共享数据。这通常包括:

  • 全局变量
    :最明显的受害者
  • 设备结构体里的成员
    :驱动程序的核心数据
  • 动态分配的、并且指针被多处引用的内存
    :多个地方引用同一块内存
  • 硬件寄存器
    :这是最典型的共享资源

在代码中找到「谁需要保护」,是解决并发问题最难的一步。这需要你对着自己的代码,像审视犯罪现场一样分析:

  • 这个变量会在open函数里被改吗?
  • 会在read函数里被读吗?
  • 如果中断来了,中断处理函数会碰它吗?
  • 如果是多核,另一个核会不会同时访问它?

一般来说,像全局变量、设备结构体这种「大家伙」,肯定是要重点保护的。至于其他的临时变量或局部缓存,就要视具体逻辑而定了。

临界区:独木桥上的通行规则

理解了要保护什么,我们还需要引入一个非常重要的概念:临界区

你可以把临界区理解为「独木桥」——一次只能过一个人。

但这个比喻有一处是不准确的:过独木桥的时候,你看得见对面有没有人;而在代码里,你看不见别的线程在干什么。

实际上,代码是静态的,执行流是动态且不可见的。你无法知道你的代码执行到哪一行时,调度器会不会突然切换到另一个线程,或者硬件会不会突然抛出一个中断。这种不可见的打断,就是「并发」的来源。

临界区就是那些「如果被打断就会出问题」的代码段。

举个简单的例子:

/* 假设 global_counter 是一个全局变量 */
global_counter++;  /* 这一行代码就是临界区! */

为什么?因为在C语言层面,这只是一行代码。但在CPU层面,这变成了三件事:

  1. 从内存读取global_counter的值到寄存器
  2. 在寄存器里加1
  3. 把结果写回内存

如果在这三步中间被打断,比如在步骤1和步骤2之间,另一个线程也读取了global_counter的值,那么两个线程都会基于同一个旧值进行加1操作。最终结果只加了1,而不是预期的2。

这就是竞争条件(Race Condition)。多个执行流「竞争」同一个资源,谁先谁后不确定,结果也不确定。

从0开始识别危险区域

现在的问题是:怎么在代码里找到这些危险区域?

这里有一个实用的方法论:

步骤1:找出所有共享数据

/* 你的驱动代码 */
staticint global_counter = 0;  /* ← 共享数据 */
staticstructmy_device_data *dev_data;/* ← 共享数据 */

staticintmy_open(struct inode *inode, struct file *file) {
/* ... */
}

staticssize_tmy_read(struct file *file, char __user *buf, size_t count, loff_t *ppos) {
/* 这些函数都会访问上面的共享数据 */
}

步骤2:找出所有访问共享数据的代码路径

/* 路径1:my_open() -> 修改 global_counter */
/* 路径2:my_read() -> 读取 global_counter */
/* 路径3:中断处理函数 -> 修改 global_counter */

步骤3:判断这些路径是否会并发执行

  • my_open()
    my_read()会被多个进程同时调用吗?
  • 中断会在my_open()执行期间发生吗?
  • 如果是多核,这些函数会在不同核心上同时运行吗?

步骤4:标记临界区

一旦你确定了哪些代码会并发执行,就把它们标记为临界区:

/* 临界区开始 */
global_counter++;
/* 临界区结束 */

这些临界区,就是我们需要加锁保护的地方。

写在最后:这只是开始

到这里,我们已经建立了一个核心认知:并发是不可避免的,我们必须主动管理它。

但识别并发只是第一步。接下来,我们需要学习如何控制并发。Linux内核提供了丰富的工具:

  • 原子操作
    :最轻量级,适合简单的计数器
  • 自旋锁
    :让CPU空转等待,适合极短的临界区
  • 信号量和互斥体
    :让线程睡眠等待,适合较长的临界区

这些工具各有各的使用场景和代价,选错了锁,比不锁更可怕。在接下来的几节里,我们会逐一拆解这些武器库,让你知道什么时候用什么,以及——更重要的是——什么时候不能用什么。

因为记住,在并发世界里,错误的锁比没有锁更危险


本章要点

  1. Linux内核中的并发来源有四个
    :多线程、内核抢占、中断、SMP多核。单核思维已不适用。
  2. 我们保护的是数据,不是代码
    。局部变量不需要保护,共享数据需要。
  3. 临界区是「如果被打断就会出问题」的代码段
    ,需要用锁保护起来。
  4. 识别并发问题的方法
    :找出共享数据 → 找出访问路径 → 判断是否并发 → 标记临界区。

相关阅读

  1. 02. 设备树语法与编译工具——读懂这张"藏宝图" - 相似度 100%
  2. 嵌入式Linux嵌入式Linux驱动开发:设备树驱动改造——从硬编码到设备树的实战之旅 - 相似度 71%
  3. 嵌入式Linux驱动开发pinctrl篇(1)——从寄存器到子系统:驱动演进之路 - 相似度 71%

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-02 23:27:42 HTTP/2.0 GET : https://f.mffb.com.cn/a/496168.html
  2. 运行时间 : 0.603062s [ 吞吐率:1.66req/s ] 内存消耗:4,617.30kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=386536aca9d5da03f1421ff18bc1d97b
  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.000570s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000686s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.017196s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.010257s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000659s ]
  6. SELECT * FROM `set` [ RunTime:0.006298s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000718s ]
  8. SELECT * FROM `article` WHERE `id` = 496168 LIMIT 1 [ RunTime:0.024622s ]
  9. UPDATE `article` SET `lasttime` = 1783006062 WHERE `id` = 496168 [ RunTime:0.010774s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 67 LIMIT 1 [ RunTime:0.011220s ]
  11. SELECT * FROM `article` WHERE `id` < 496168 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.014793s ]
  12. SELECT * FROM `article` WHERE `id` > 496168 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.036870s ]
  13. SELECT * FROM `article` WHERE `id` < 496168 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.115892s ]
  14. SELECT * FROM `article` WHERE `id` < 496168 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.107447s ]
  15. SELECT * FROM `article` WHERE `id` < 496168 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.120304s ]
0.604752s