当前位置: 首页 > news >正文

浅析Linux SCSI子系统:调试方法

文章目录

    • SCSI日志调试功能
      • scsi_logging_level
      • 调整SCSI日志等级
    • SCSI trace events
      • 使能SCSI trace events
        • 方式一:通过set_event接口
        • 方式二:通过enable
      • 跟踪trace信息
    • 相关参考

SCSI日志调试功能

SCSI子系统支持内核选项CONFIG_SCSI_LOGGING配置日志调试功能:
在这里插入图片描述

scsi_logging_level

scsi_logging_level定义为一个4字节的值,表示了SCSI的各种日志类型及对应的日志等级:

unsigned int scsi_logging_level;

scsi_logging_level被分成10个3位的字段,每个字段定义为一种日志类型,字段取值范围为0~7,表示了对应日志类型的打印等级。SCSI支持的日志类型如下:

  • SCSI_LOG_ERROR
  • SCSI_LOG_TIMEOUT_BITS
  • SCSI_LOG_SCAN_BITS
  • SCSI_LOG_MLQUEUE_BITS
  • SCSI_LOG_MLCOMPLETE_BITS
  • SCSI_LOG_LLQUEUE_BITS
  • SCSI_LOG_LLCOMPLETE_BITS
  • SCSI_LOG_HLQUEUE_BITS
  • SCSI_LOG_HLCOMPLETE_BITS
  • SCSI_LOG_IOCTL

调整SCSI日志等级

SCSI日志调试可以通过修改/proc/sys/devscsi/logging_level进行控制:

echo <bitmask> > /proc/sys/dev/scsi/logging_level   # 0表示关闭,-1表示全开

通过proc文件系统的方式需要手动计算bitmask,相对比较繁琐,lsscsi软件包提供了scsi_logging_level命令行工具来控制SCSI子系统的打印等级:

-s, --set:设置SCSI日志类型打印等级 
-g, --get: 获取当前SCSI日志类型等级设置
-a, --all:设置所有SCSI日志类型的打印等级
-E, --error :设置SCSI_LOG_ERROR的打印等级
-T, --timeout:设置SCSI_LOG_TIMEOUT的打印等级
-S, --scan:设置SCSI_LOG_SCAN的打印等级
-M, --midlevel:设置SCSI_LOG_MLQUEUE和SCSI_LOG_MLCOMPLETE的打印等级--mlqueue:设置SCSI_LOG_MLQUEUE的打印等级--mlcomplete:设置SCSI_LOG_MLCOMPLETE的打印等级
-L, --lowlevel:设置SCSI_LOG_LLQUEUE和SCSI_LOG_LLCOMPLETE的打印等级--llqueue:设置SCSI_LOG_LLQUEUE的打印等级--llcomplete:设置SCSI_LOG_LLCOMPLETE的打印等级
-H, --highlevel:设置SCSI_LOG_HLQUEUE和SCSI_LOG_HLCOMPLETE的打印等级--hlqueue:设置SCSI_LOG_HLQUEUE的打印等级--hlcomplete:设置SCSI_LOG_HLCOMPLETE的打印等级
-I, --ioctl:设置SCSI_LOG_IOCTL的打印等级

scsi_logging_level命令使用示例:
在这里插入图片描述

SCSI trace events

SCSI子系统注册了一些trace events,这些trace events可以用来跟踪特定路径上的行为,已支持的trace events有:
在这里插入图片描述
这些trace events也可以在/sys/kernel/debug/tracing/events/scsi目录下找到:
在这里插入图片描述

使能SCSI trace events

方式一:通过set_event接口

* 使能特定的event:echo 'scsi_dispatch_cmd_done' > /sys/kernel/debug/tracing/set_event  
* 使能SCSI系统的所有event:echo 'scsi:*'  > /sys/kernel/debug/tracing/
* 禁用特定的event:echo '!scsi_dispatch_cmd_done' > /sys/kernel/debug/tracing/set_event 

方式二:通过enable

* 使能特定的event:echo 1 > /sys/kerne/debug/tracing/events/scsi/scsi_dispatch_cmd_done/enable
* 使能SCSI系统的所有event:echo 1 > /sys/kernel/debug/tracing/event/scsi/enable
* 禁用特定的event:echo '!scsi_dispatch_cmd_done' > /sys/kernel/debug/tracing/set_event 

跟踪trace信息

SCSI子系统注册的trace events有限,只能查看位于IO请求下发、返回的一些信息,对于日常问题定位可能帮助不大,但可以辅助用来分析SCSI的运行流程。
在这里插入图片描述

相关参考

  • 《存储技术原理分析:基于Linux 2.6内核源代码分析》
  • 深入浅出SCSI子系统
  • Tracing event
http://www.lryc.cn/news/135574.html

相关文章:

  • 【Unity3D】水面特效
  • CSS中的flex布局详细讲解
  • Python功能制作之简单的音乐播放器
  • GAN生成对抗模型根据minist数据集生成手写数字图片
  • 【K8S源码之Pod漂移】整体概况分析 controller-manager 中的 nodelifecycle controller(Pod的驱逐)
  • [保研/考研机试] KY212 二叉树遍历 华中科技大学复试上机题 C++实现
  • CSS笔记
  • 链栈Link-Stack
  • Ubuntu 20系统WIFI设置静态IP地址,以及断连问题
  • (一)idea连接GitHub的全部流程(注册GitHub、idea集成GitHub、增加合作伙伴、跨团队合作、分支操作)
  • -bash: java: command not found笔记
  • C++ typename and .template
  • uniapp,使用canvas制作一个签名版
  • 【大数据】Flink 详解(五):核心篇 Ⅳ
  • 设计模式-建造者模式
  • flutter 设置app图标
  • 守护网络安全:深入了解DDOS攻击防护手段
  • 计组 | 寻址方式
  • matlab工具箱Filter Designer设计butterworth带通滤波器
  • Python学习笔记第六十天(Matplotlib Pyplot)
  • 服务器自动备份、打包、传输脚本
  • Docker 的数据管理 网络通信
  • 目标检测YOLO实战应用案例100讲-基于孤立森林算法的高光谱遥感图像异常目标检测
  • excel中两列数据生成折线图
  • JS加密的域名锁定功能,JShaman支持泛域名
  • 概率论与数理统计:第七章:参数估计 第八章:假设检验
  • 【Kubernetes】Kubernetes的监控工具Promethues
  • 【linux】2 Linux编译器-gcc/g++和Linux调试器-gdb
  • 【力扣每日一题】2023.8.17 切披萨的方案数
  • Linux调试器-gdb使用