当前位置:首页>Linux>跟 AI 学 Linux:为什么 TCP Fast Open 很鸡肋?

跟 AI 学 Linux:为什么 TCP Fast Open 很鸡肋?

  • 2026-02-05 00:38:51
跟 AI 学 Linux:为什么 TCP Fast Open 很鸡肋?

1. 议题

上篇讲到 TCP 三次握手至少需要一个 RTT。短连接频繁的 Web 应用累积延迟很可观,能不能握手时就把数据发过去?

TCP Fast Open (TFO) 就是 Google 提出的解决方案,概念很漂亮,但实际没什么人用。为什么?

2. 对话

2.1 问

TCP 建立连接需要三次握手,这会造成一个 RTT 的延迟。我听说 TCP Fast Open (TFO) 可以解决这个延迟问题,但是我不了解其原理,请为我详细讲解一下。

2.2 答

TCP Fast Open (TFO) 的核心逻辑很简单:既然我们之前认识,这次能不能跳过寒暄,直接带货?

TFO 的工作原理

TFO 首次连接不能提速,第二次开始生效。它用了 Cookie 机制。

第一步:初次见面(获取 Cookie)

  1. 1. 客户端发送一个 SYN 包,里面包含一个特殊的 TFO 选项,请求一个 Cookie。
  2. 2. 服务器生成一个加密的 Cookie 随 SYN-ACK 发回。
  3. 3. 客户端保存这个 Cookie。这次握手依然是普通的 1-RTT 延迟。

第二步:再次连接(快速打开)

当客户端再次连接该服务器时:

  1. 1. 直接带货: 客户端发送 SYN 包,包里同时塞进了 Cookie 和 实际请求数据 (Data)
  2. 2. 服务器校验: 服务器验证 Cookie 合法后,立即把数据交给应用层处理,并返回 SYN-ACK 和响应数据。

TFO 的优势与挑战

优势

  • • 后续连接数据在 SYN 阶段就开始传输,理论延迟降到 0-RTT。
  • • Cookie 校验防止攻击者伪造大量带数据的 SYN 包。

挑战(为什么没能全面普及)

  • • 中间设备问题:老旧防火墙或路由器看到 SYN 包带数据,认为不符合规范直接丢弃。
  • • 幂等性问题:SYN 包重发会导致服务器收到两次相同请求。如果是"扣款"操作就麻烦了,所以 TFO 通常只用于幂等操作。

总结对比

特性
标准 TCP 握手
TCP Fast Open (TFO)
首字节延迟
1 RTT
0 RTT (非首次连接)
握手过程
先握手,后传数据
握手的同时传数据
安全性
基础序列号校验
加密 Cookie 校验

2.3 思考

原理很简单。我更好奇"为什么没能全面普及"。

2.4 问

请再详细解释一下"为什么没能全面普及"。

我有两个疑问:

  1. 1. 包重发可能是低概率事件,但这明显存在重放攻击漏洞,没有其他防御机制吗?
  2. 2. 应用层实现幂等性是个很强的约束,某种程度上不现实,这方面有什么最佳实践吗?

2.5 答

TFO 没有全面普及的根本原因不是"实现难",而是它在 TCP 层无法同时满足:

  • • 0-RTT
  • • 无状态服务器
  • • 无重放风险

这三者在实现上是冲突的。

重放攻击为什么在 TFO 里"几乎无解"?

Cookie 只能证明"你来过",但不能证明"这是第一次"。 这是 TFO 的致命问题。

为什么 TCP 层无法解决?

  • • TCP 服务器在 SYN 阶段是“无状态的”
  • • IP 层 + TCP 层不保证唯一性

为什么不能给 Cookie 加时间戳 / nonce?

  • • 看起来可行,但实际上不行。问题仍然回到:服务器需要状态。

那 TLS 1.3 0-RTT 为什么能"更好地解决"?

关键区别在这:

项目
TFO
TLS 1.3
层次
TCP
应用层
服务器状态
无状态
有状态 / 半有状态
重放防御
几乎没有
可选 Anti-Replay

TLS 可以限制 0-RTT 数据有效时间、绑定 session、在负载均衡器层做 replay cache,但 TCP 层做不到这些。

TFO 的重放攻击不是"实现缺陷",而是 TCP 层无状态设计与 0-RTT 的根本冲突,协议层无法彻底解决。

幂等性要求太强了,工程上怎么办?

让应用层实现幂等性在通用场景下是不现实的。 现实世界采用的是有边界的幂等,而不是绝对幂等。

最佳实践一:限制 TFO 的使用范围

  • • GET / HEAD
  • • 查询类 RPC
  • • 无副作用的读操作

最佳实践二:业务幂等键

即使不用 TFO,这也是现代系统的标配。

最佳实践三:读写分离

  • • TFO:只用于读路径
  • • 写路径:走普通 TCP / TLS

最佳实践四:干脆不用 TFO(现实选择)

这也是为什么 HTTP/2、HTTP/3、QUIC 成为主流方案。它们把 0-RTT 的复杂性推到了更高层,换取可控性。

最终总结

TCP Fast Open 没能全面普及,核心原因在于 TCP 层的无状态设计使其无法彻底防御重放攻击,因此协议只能把安全责任推给应用层。而应用层幂等性对写操作约束过强,工程上难以通用落地,最终在公网场景被 QUIC 等方案取代。

2.6 思考

我明白了!TFO 的问题在于定位错误,0-RTT 需要在能持有状态、理解语义的层实现。

3. 实验

我们在 Linux 上体验一下 TFO 的使用,确保内核版本为 3.7+,并开启内核参数。

# 查看 TFO 状态# 0: 关闭# 1: 仅开启客户端# 2: 仅开启服务端# 3: 双方都开启cat /proc/sys/net/ipv4/tcp_fastopen

完整代码位于我的 gitee 仓库[1]

服务端关键代码

// 启用 TCP Fast Open// queue_len 指定了等待 TFO cookie 的最大连接数if (setsockopt(server_fd, SOL_TCP, TCP_FASTOPEN, &queue_len, sizeof(queue_len)) < 0) {    perror("setsockopt TCP_FASTOPEN");    fprintf(stderr, "Note: TCP_FASTOPEN may not be supported on this system\n");    // 继续执行,即使 TFO 不可用} else {    printf("TCP Fast Open enabled on server (queue length: %d)\n", queue_len);}

通过 setsockopt 设置当前的 socket 开启 TCP Fast Open。

客户端关键代码

// 使用 sendto() 发送数据,系统会自动建立连接// 如果是第一次连接,服务器会返回 cookie// 如果已有 cookie,可以在 SYN 包中发送数据n = sendto(sock_fd, message, msg_len, MSG_FASTOPEN,           (struct sockaddr *)&server_addr, sizeof(server_addr));if (n < 0) {    if (errno == EINVAL) {        // MSG_FASTOPEN 不支持,回退到普通 connect + send        printf("MSG_FASTOPEN not supported, falling back to regular TCP\n");        if (connect(sock_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) < 0) {            perror("connect");            close(sock_fd);            exit(1);        }        n = send(sock_fd, message, msg_len, 0);        if (n < 0) {            perror("send");            close(sock_fd);            exit(1);        }    } else {        perror("sendto (MSG_FASTOPEN)");        close(sock_fd);        exit(1);    }}

客户端直接使用 sendto,而不是先 connect,其中设置了 MSG_FASTOPEN 标志。

抓包观察

14:23:39.554524 IP 127.0.0.1.12848 > 127.0.0.1.8888: Flags [S], seq 2541048048, win 43690, options [mss 65495,sackOK,TS val 2006339982 ecr 0,nop,wscale 10,tfo  cookiereq,nop,nop], length 014:23:39.554533 IP 127.0.0.1.8888 > 127.0.0.1.12848: Flags [S.], seq 2446151388, ack 2541048049, win 43690, options [mss 65495,sackOK,TS val 2006339982 ecr 2006339982,nop,wscale 10,tfo  cookie 916c8ee1ffd58975,nop,nop], length 014:23:39.554541 IP 127.0.0.1.12848 > 127.0.0.1.8888: Flags [P.], seq 2541048049:2541048071, ack 2446151389, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 2214:23:39.554553 IP 127.0.0.1.8888 > 127.0.0.1.12848: Flags [.], ack 2541048071, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 014:23:39.554615 IP 127.0.0.1.8888 > 127.0.0.1.12848: Flags [P.], seq 2446151389:2446151411, ack 2541048071, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 2214:23:39.554628 IP 127.0.0.1.12848 > 127.0.0.1.8888: Flags [P.], seq 2541048071:2541048098, ack 2446151411, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 2714:23:39.554639 IP 127.0.0.1.8888 > 127.0.0.1.12848: Flags [P.], seq 2446151411:2446151438, ack 2541048098, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 2714:23:39.554666 IP 127.0.0.1.12848 > 127.0.0.1.8888: Flags [F.], seq 2541048098, ack 2446151438, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 014:23:39.554680 IP 127.0.0.1.8888 > 127.0.0.1.12848: Flags [F.], seq 2446151438, ack 2541048099, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 014:23:39.554687 IP 127.0.0.1.12848 > 127.0.0.1.8888: Flags [.], ack 2446151439, win 43, options [nop,nop,TS val 2006339982 ecr 2006339982], length 0

首次连接

  • • 客户端发送 SYN: 客户端开启了 TFO,但当前还没有 Cookie,所以请求服务端给一个 Cookie,也就是 tfo  cookiereq 的含义。
    • • 注意:虽然代码中 sendto 函数传了数据,但内核发现当前没有 cookie,所以不会把数据放进 SYN 包。
  • • 服务端回应 SYN+ACK: 服务端支持 TFO,生成了一个 Cookie tfo  cookie 916c8ee1ffd58975
  • • 客户端发送 PSH + ACK:完成 TCP 建连流程,并发送数据
14:26:09.276789 IP 127.0.0.1.31494 > 127.0.0.1.8888: Flags [S], seq 7122689:7122711, win 43690, options [mss 65495,sackOK,TS val 2006489704 ecr 0,nop,wscale 10,tfo  cookie 916c8ee1ffd58975,nop,nop], length 2214:26:09.276805 IP 127.0.0.1.8888 > 127.0.0.1.31494: Flags [S.], seq 2160883626, ack 7122712, win 43690, options [mss 65495,sackOK,TS val 2006489704 ecr 2006489704,nop,wscale 10], length 014:26:09.276811 IP 127.0.0.1.31494 > 127.0.0.1.8888: Flags [.], ack 2160883627, win 43, options [nop,nop,TS val 2006489704 ecr 2006489704], length 014:26:09.276850 IP 127.0.0.1.8888 > 127.0.0.1.31494: Flags [P.], seq 2160883627:2160883649, ack 7122712, win 43, options [nop,nop,TS val 2006489705 ecr 2006489704], length 2214:26:09.276852 IP 127.0.0.1.31494 > 127.0.0.1.8888: Flags [.], ack 2160883649, win 43, options [nop,nop,TS val 2006489705 ecr 2006489705], length 014:26:09.276869 IP 127.0.0.1.31494 > 127.0.0.1.8888: Flags [P.], seq 7122712:7122739, ack 2160883649, win 43, options [nop,nop,TS val 2006489705 ecr 2006489705], length 2714:26:09.276872 IP 127.0.0.1.8888 > 127.0.0.1.31494: Flags [.], ack 7122739, win 43, options [nop,nop,TS val 2006489705 ecr 2006489705], length 014:26:09.276882 IP 127.0.0.1.8888 > 127.0.0.1.31494: Flags [P.], seq 2160883649:2160883676, ack 7122739, win 43, options [nop,nop,TS val 2006489705 ecr 2006489705], length 2714:26:09.276916 IP 127.0.0.1.31494 > 127.0.0.1.8888: Flags [F.], seq 7122739, ack 2160883676, win 43, options [nop,nop,TS val 2006489705 ecr 2006489705], length 014:26:09.276929 IP 127.0.0.1.8888 > 127.0.0.1.31494: Flags [F.], seq 2160883676, ack 7122740, win 43, options [nop,nop,TS val 2006489705 ecr 2006489705], length 014:26:09.276935 IP 127.0.0.1.31494 > 127.0.0.1.8888: Flags [.], ack 2160883677, win 43, options [nop,nop,TS val 2006489705 ecr 2006489705], length 0

第二次连接

  • • 客户端发送 SYN: 客户端开启了 TFO,当前有 Cookie,那么直接带上数据,也就是 tfo  cookie 916c8ee1ffd58975 的含义。
  • • 服务端回应 SYN+ACK: 服务端确认接受数据
    • • 注意:此时 ACK 的确认号为 7122712 = 7122689(序列号)+ 22(数据长度)+ 1(SYN 标志占一个序列号)
  • • 客户端发送 ACK:完成 TCP 建连流程。此时数据已在前两次交互中发送完成。

4. 内核实现

分析了 TCP Fast Open 的设计问题,也实操了代码实现,接下来看看 Linux 内核的实现。

4.1 任务

请梳理 @net/ 目录下关于 TCP Fast Open 的源码,生成报告。需要讲清楚:

  • • cookies 的生成机制
  • • cookies 的存储策略
  • • 等待队列的机制
  • • Linux 提供的可配置参数
  • • 以及你认为的要点

4.2 报告

内核版本: Linux 5.15.198分析范围: net/ 目录下 TCP Fast Open (TFO) 实现

完成的报告在 02_TCP_Fast_Open_源码分析报告.md[1],这里仅摘要关键点。

Cookie 生成机制

  • • 算法: SipHash(源IP + 目标IP, 128-bit密钥) → 64-bit cookie
  • • 双密钥支持: 主密钥 + 备份密钥,实现平滑密钥轮换

Cookie 存储策略

  • • 客户端: 按目标地址缓存 (tcpm_daddr),存储 cookie + MSS + syn_loss
  • • 服务器端: 不持久化,每次实时验证
  • • 并发保护: seqlock (客户端) + RCU (密钥)

等待队列机制

  • • max_qlen: 最大 pending 请求数 (可配置)
  • • rskq_rst_head/tail: 跟踪产生 RST 的请求 (防攻击)
  • • 回收策略: 队列满时尝试回收过期请求 (60秒超时)

双密钥轮换

  • • 旧连接 → 主密钥验证 → 通过
  • • 新连接 → 备份密钥生成 → 平滑过渡

中间盒防护 (指数退避)

  • • 触发: 乱序 FIN/RST, 3次超时
  • • 禁用: 1h → 2h → 4h → ... → 64h
  • • 恢复: 成功的 TFO 连接

防攻击设计

  • • Cookie 验证 (防 SYN flood)
  • • RST 请求保留 60 秒 (防绕过队列限制)
  • • syn_loss 计数 (跟踪连接质量)

可配置参数

参数
路径
类型
默认值
说明
tcp_fastopen
/proc/sys/net/ipv4/tcp_fastopen
int
0x1
TFO 全局开关
tcp_fastopen_key
/proc/sys/net/ipv4/tcp_fastopen_key
string
随机
TFO 密钥 (16/32 bytes hex)
tcp_fastopen_blackhole_timeout_sec
/proc/sys/net/ipv4/tcp_fastopen_blackhole_timeout_sec
int
0
黑洞检测超时 (秒)

5. 总结

TCP Fast Open 让 TCP 的行为向 UDP 靠拢,但 TCP 层的无状态设计使其无法彻底防御重放攻击,所以在公网环境无法通用落地,但在内网特定场景还是有用武之地。

最终 Google 也意识到了这个问题,转向推广 HTTP/3 (QUIC) 协议。


1. https://gitee.com/shichaoyuan/learn-linux-with-ai↩︎

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-07 15:14:57 HTTP/2.0 GET : https://f.mffb.com.cn/a/472807.html
  2. 运行时间 : 0.118592s [ 吞吐率:8.43req/s ] 内存消耗:4,693.37kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=07adf80df7bad44e391af915d93d0c30
  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.000425s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000748s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.006613s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.005606s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000891s ]
  6. SELECT * FROM `set` [ RunTime:0.003246s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000870s ]
  8. SELECT * FROM `article` WHERE `id` = 472807 LIMIT 1 [ RunTime:0.004209s ]
  9. UPDATE `article` SET `lasttime` = 1770448497 WHERE `id` = 472807 [ RunTime:0.002947s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 67 LIMIT 1 [ RunTime:0.000328s ]
  11. SELECT * FROM `article` WHERE `id` < 472807 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000557s ]
  12. SELECT * FROM `article` WHERE `id` > 472807 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000708s ]
  13. SELECT * FROM `article` WHERE `id` < 472807 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001778s ]
  14. SELECT * FROM `article` WHERE `id` < 472807 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.011019s ]
  15. SELECT * FROM `article` WHERE `id` < 472807 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.005476s ]
0.120277s