当前位置:首页>Linux>Ubuntu / Linux 系统下 USB 工业相机无法被 Cheese 读取的原因分析与工程级解决方案(附Python / C++代码)

Ubuntu / Linux 系统下 USB 工业相机无法被 Cheese 读取的原因分析与工程级解决方案(附Python / C++代码)

  • 2026-02-05 22:25:20
Ubuntu / Linux 系统下 USB 工业相机无法被 Cheese 读取的原因分析与工程级解决方案(附Python / C++代码)

一、问题

上一篇博文中,讲解了Ubun/Liunx系统上如何使用茄子(Cheese)相机读取USB网络摄像头的方法,对于部分厂家的USB摄像头任然不能正常读取视频,这是工业相机常见问题。

在 Linux 系统(Ubuntu 20.04)下使用 USB相机进行视频采集时,遇到了如下问题:

  • Windows 下使用 PotPlayer、VLC 等工具可以 正常显示红外视频

Linux 下:

  • Cheese 打不开(报错:播放网络摄像头录制的视频时出错)

  • ffplay / VLC 能够正常显示

  • OpenCV VideoCapture 无法读取

  • 最终只能通过 FFmpeg 管道 + OpenCV 才成功稳定读取

本篇文章将对该问题进行系统性拆解与工程级解决。

二、设备真实情况分析

2.1 安装v4l-utils

安装v4l-utils指令:

sudo apt install v4l-utils

2.2 查看USB摄像头列表

查看USB摄像头列表,执行下面指令:

v4l2-ctl --list-devices

2.3 查看USB摄像头支持的格式

查看USB摄像头支持的格式,执行下面指令:

v4l2-ctl -d /dev/video0 --list-formats-ext

输出USB摄像头支持的输出格式如下:

从上面的输出参数可以看出,USB设备驱动正常;UVC协议标准;视频流是标准的YUYV422。USB设备是一台完全标准的UVC USB工业相机。

三、问题根因分析:Cheese 为什么会失败?

3.1 Cheese 架构

Cheese 内部技术架构,Cheese 采用的是:

v4l2src → videoconvert → videoscale → autovideosink

3.2 工业红外相机的特殊性

工业相机普遍具有:

3.3 关键验证实验

使用手动 GStreamer pipeline,终端中输入下面指令,如下:

gst-launch-1.0 v4l2src device=/dev/video0 ! \video/x-raw,format=YUY2,width=640,height=512,framerate=30/1 ! \videoconvert ! autovideosink

可以正常显示画面。这说明:GStreamer 本身完全支持该相机。

3.4 cheese失败原因

真正失败的是 Cheese 的自动协商机制,Cheese 不提供:format 指定、分辨率锁定和framerate 约束,caps negotiation 失败 → pipeline 构建失败 → 直接报错。

四、为什么 ffplay / VLC 却能成功?

ffmpeg 采用的解码链路:

v4l2 → libavdevice → libavcodec → swscale

ffmpeg 的核心优势:

FFmpeg 的 swscale 具有极强的 stride 与内存对齐容错能力,可以自动修复各种怪异分辨率问题。这也是:几乎所有工业视觉系统底层最终都会使用 FFmpeg 的根本原因。

五、示例读取USB工业相机

5.1 安装ffmpeg

安装ffmpeg在终端执行指令:

sudo apt install ffmpeg

5.2 方案1:ffplay 直接播放

FFmpeg 多媒体框架里的 ffplay 播放器,执行下面指令,指定设备输出格式,输出分辨率和设备ID,如下:

ffplay -f v4l2 -input_format yuyv422 -video_size 640x512 -i /dev/video0

执行上面指令后,打开的实时视频画面如下:

5.3 方案2:mpv 播放(画质更好)

mpv 播放,执行下面指令,指定设备输出格式,输出分辨率和设备ID,如下:

mpv av://v4l2:/dev/video0 --demuxer-lavf-format=v4l2 --demuxer-lavf-o=input_format=yuyv422,video_size=640x512

补:此方法我自己测试发现,视频成像画面有一点延迟。

5.4 代码读取USB工业相机

5.4.1 读取流程

使用代码读取USB工业相机的流程如下:

USB 红外相机v4l2FFmpegpipePython/ C++OpenCV

5.4.2 Python代码

5.4.2.1 FFmpeg方法

完整的Python示例代码如下:

mport subprocess               # 用于调用系统命令,启动FFmpeg进程                        import numpy as np              import cv2                      # 定义相机分辨率w, h = 640512# 构造FFmpeg命令参数cmd = [    'ffmpeg',                        # 要调用的系统命令    '-f''v4l2',                    # 输入格式:v4l2(Linux视频设备标准协议,必选)    '-input_format''yuyv422',      # 相机原始输入格式:yuyv422    '-video_size'f'{w}x{h}',       # 采集分辨率:和上面定义的w/h一致    '-i''/dev/video0',             # 输入设备:高德相机的Linux节点(根据实际情况修改)    '-f''rawvideo',                # 输出格式:原始视频流(无压缩,方便Python解析)    '-pix_fmt''bgr24',             # 输出像素格式:bgr24(OpenCV默认支持的格式,必选)    '-'                              # 输出位置:标准输出(stdout),将处理后的流传给Python]# 执行这行代码后,FFmpeg 就会开始从/dev/video0读取相机流,解码并转成 BGR24 格式,通过管道传给 Python。# 启动 FFmpeg 子进程,建立管道通信 。# subprocess.Popen:启动一个独立的 FFmpeg 子进程,不会阻塞 Python 主进程,实现实时流读取# stdout=subprocess.PIPE:将 FFmpeg 的标准输出(处理后的 BGR 流)和 Python 进程的管道(pipe) 绑定,Python 可以通过pipe.stdout读取 FFmpeg 的输出数据;# bufsize=10**8:设置超大缓冲区(100MB),避免因红外相机流传输速度快导致的数据丢失 / 卡顿,保证实时性。pipe = subprocess.Popen(cmd, stdout=subprocess.PIPE, bufsize=10**8)# 循环读取帧并处理显示(主循环)while True:    # 1. 从管道读取一帧BGR24格式的原始数据    raw = pipe.stdout.read(w * h * 3)    # 校验:一帧BGR24数据的字节数必须是 宽×高×3(每个像素3个字节:B/G/R)    if len(raw) != w * h * 3:        print("读取失败")        break    # 2. 将二进制原始流转成OpenCV可处理的numpy数组    frame = np.frombuffer(raw, dtype=np.uint8).reshape((h, w, 3))    # 3. 将彩色BGR帧转成灰度图(红外相机成像通常看灰度图更清晰)    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)    # 4. 显示灰度图,窗口名称为"IR"(Infrared红外)    cv2.imshow("IR", gray)    # 5. 按键退出:按下ESC键(ASCII码27),终止循环    if cv2.waitKey(1) == 27:        break

5.4.2.2 GStreamer方法

前面3.3小节中已经验证,也可以用GStreamer抓取视频流,但常规直接使用pip install opencv-python安装的OpenCV包中,默认不启用 GStreamer,因为:GStreamer 依赖复杂,与 conda 虚拟环境冲突多,打包困难, 所以工业级视频采集功能被阉割,如下:

直接使用会提示报错:❌ GStreamer 管线打开失败。如下:

想要开启GStreamer,必须自己去OpenCV官网下载源码进行编译 OpenCV + GStreamer才行,学者自行编译。

使用GStreamer方法的完整示例代码如下:

import cv2import timeprint("等待相机初始化...")gst_pipeline = (    "v4l2src device=/dev/video0 ! "    "video/x-raw,format=YUY2,width=640,height=512,framerate=30/1 ! "    "videoconvert ! appsink")cap = cv2.VideoCapture(gst_pipeline, cv2.CAP_GSTREAMER)if not cap.isOpened():    print("❌ GStreamer 管线打开失败")    exit(1)print("✅ 相机已成功打开")while True:    ret, frame = cap.read()    if not ret:        print("读取失败")        continue    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)    cv2.imshow("IR", gray)    if cv2.waitKey(1) == 27:        break

5.4.3 C++代码

完整的C++示例代码如下:

#include<iostream>#include<cstdio>#include<vector>#include<opencv2/opencv.hpp>using namespace std;// ------------------- 参数配置 -------------------// 相机分辨率static const int WIDTH  = 640;static const int HEIGHT = 512;// 每帧字节数:BGR24 = 3字节 / 像素static const int FRAME_SIZE = WIDTH * HEIGHT * 3;// ------------------------------------------------intmain(){    cout << "启动红外相机采集..." << endl;    /*     * 构造 FFmpeg 采集命令(与 Python 完全一致)     *     * -f v4l2                 : 使用 Linux V4L2 采集接口     * -input_format yuyv422  : 指定相机原始输出格式(关键参数)     * -video_size 640x512    : 指定采集分辨率     * -i /dev/video0         : 采集设备节点     * -f rawvideo            : 输出原始视频流(无压缩)     * -pix_fmt bgr24         : 转换为 OpenCV 友好的 BGR24     * -                       : 输出到 stdout(通过管道传给 C++)     */    string cmd =        "ffmpeg -loglevel quiet "        "-f v4l2 "        "-input_format yuyv422 "        "-video_size 640x512 "        "-i /dev/video0 "        "-f rawvideo "        "-pix_fmt bgr24 "        "-";    /*     * popen():     *   启动 FFmpeg 进程,并打开其 stdout 管道,供 C++ 实时读取视频流     */    FILE* pipe = popen(cmd.c_str(), "r");    if (!pipe)    {        cerr << "❌ FFmpeg 启动失败!" << endl;        return -1;    }    cout << "✅ FFmpeg 采集管道已建立,开始读取视频流..." << endl;    // 用于存储一帧原始 BGR 数据    vector<unsignedcharbuffer(FRAME_SIZE);    // OpenCV Mat,直接包装 raw buffer    cv::Mat frame(HEIGHT, WIDTH, CV_8UC3);    cv::Mat gray;    while (true)    {        /*         * 从 FFmpeg 管道中读取一帧         * 每次必须完整读取 WIDTH * HEIGHT * 3 字节         */        size_t bytes = fread(buffer.data(), 1, FRAME_SIZE, pipe);        if (bytes != FRAME_SIZE)        {            cerr << "❌ 读取失败,数据长度异常:" << bytes << endl;            break;        }        // 将 buffer 映射为 OpenCV Mat        memcpy(frame.data, buffer.data(), FRAME_SIZE);        // BGR → 灰度(红外图像通常显示灰度)        cv::cvtColor(frame, gray, cv::COLOR_BGR2GRAY);        // 显示图像        cv::imshow("IR", gray);        // ESC 退出        if (cv::waitKey(1) == 27)            break;    }    // 关闭管道    pclose(pipe);    return 0;}

5.4.4 视频输出

使用上面代码实时读取视频流输出如下:

六、总结

本文分析了Linux系统下USB工业相机无法正常读取视频的问题。通过v4l-utils工具检测发现设备驱动正常,视频流为标准YUYV422格式。Cheese相机因自动协商机制失败而报错,而ffplay/VLC通过FFmpeg的强容错能力可稳定播放。文章提供了两种解决方案:使用ffplay或mpv直接播放,以及通过Python / C++代码结合FFmpeg管道读取视频流。关键发现是工业相机的非标准分辨率(640×512)和YUYV灰度流导致自动协商异常,而FFmpeg的swscale组件能有效处理这些特殊格式。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-07 17:05:20 HTTP/2.0 GET : https://f.mffb.com.cn/a/473767.html
  2. 运行时间 : 0.209610s [ 吞吐率:4.77req/s ] 内存消耗:4,335.84kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=4b228def1b9ea317e189ec6f4bdee1f5
  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.001381s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001616s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000658s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.001714s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001406s ]
  6. SELECT * FROM `set` [ RunTime:0.001753s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001686s ]
  8. SELECT * FROM `article` WHERE `id` = 473767 LIMIT 1 [ RunTime:0.003474s ]
  9. UPDATE `article` SET `lasttime` = 1770455120 WHERE `id` = 473767 [ RunTime:0.008784s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 67 LIMIT 1 [ RunTime:0.001716s ]
  11. SELECT * FROM `article` WHERE `id` < 473767 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001232s ]
  12. SELECT * FROM `article` WHERE `id` > 473767 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.008369s ]
  13. SELECT * FROM `article` WHERE `id` < 473767 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.009379s ]
  14. SELECT * FROM `article` WHERE `id` < 473767 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.004214s ]
  15. SELECT * FROM `article` WHERE `id` < 473767 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.004917s ]
0.213229s