热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

2013337朱荟潼Linux第十八章读书笔记——调试

第十八章调试0.总结oops内核的调试配置用Git进行二分搜索bug总会有,简洁描述发给LKML1.准备开始在用户级的程序里,bug表现比较直接;在内核中却不清晰。2.内核中的bug多种多样、变

第十八章 调试

0.总结

  • oops
  • 内核的调试配置
  • 用Git进行二分搜索
  • bug总会有,简洁描述发给LKML

1. 准备开始

  • 在用户级的程序里,bug表现比较直接;在内核中却不清晰。

2. 内核中的bug

  • 多种多样、变化多端。
  • 引用空指针会产生一个oops;垃圾数据会导致系统崩溃。
  • 定时限制和竞争条件都允许多个线程在内核中同时运行产生的结果。

3. 通过打印来调试

3.1 健壮性

  • printk()函数任何时候地方都可以调用它。

3.2 日志等级

  • printk()可以指定一个日志级别【与printf()最大区别】。
  • 内核判断是否在终端上打印消息的依据。
  • 指定一个记录级别的方式:

  • KERN_WARING和KERN_DEGUG是中的简单宏定义。
  • 内核用指定的记录等级和当前终端的记录等级console_loglevel来决定是不是向终端上打印。
  • 默认级别:KERN_WARNING。
  • 按照自己想法赋予记录等级方法:

3.3 记录缓冲区

3.4 syslogd和klogd

3.5 从printf()到printk()的转换

  • 错误中培养新习惯。

4. oops

  • 内核告知用户有不幸发生的最常见方式。
  • 内核发布oops会向终端输出的内容:

    1.错误消息;
    2.寄存器中保存的信息;
    3.可供跟踪的回溯线索。
  • oops发生时间出现的状况:

  • oops包含信息:

4.1 ksymoops

  • 将回溯线索中的地址转化成符号名称,调用ksymoops命令并提供System.map:

    ksymoops saved_oops.txt

4.2 kallsyms

  • CONFIG_KALLSYMS 定义配置选项启用。
  • CONFIG_KALLSYMS_ALL 存放函数名称;存放所有符号名称。
  • CONFIG_KALLSYMS_EXTRA_PASS 引起内核构建中再次忽略内核的目标代码。

5. 内核调试配置选项

  • 在内核配置编辑器的内核开发菜单项中,依赖CONFIG_DEBUG_KERNEL。

6. 引发bug并打印信息

  • 常用BUG()和BUG_ON()。
  • 调用会引发oops

7. 神奇的系统请求键

  • 通过定义CONFIG_MAGIC_SYSRQ配置选项来启用。
  • 内核可以通过特殊的组合键和内核进行通信。
  • sysctl来标记该特性的开或关。需要启用时:

    echo 1 > /proc/sys/kernel/sysrq

8. 内核调试器的传奇

8.1 gdb

  • 针对内核启动调试器的方法和对进程的方法大致相同:

    gdb vmlinux /proc/kcore
    vmlinux文件是未压缩的内核映像;
    /proc/kcore是一个参数选项,作为core文件来用,只有超级用户才能读取此文件的数据。
  • 打印一个变量的值:

    p global_variable
  • 反汇编一个函数:

    disassemble function
  • 局限性:

    不能修改内核数据;
    不能单步执行内核代码;
    不能加断点

8.2 kgdb

  • 是一个补丁,可在远端主机上通过串口利用gdb的所有功能对内核进行调试。

9. 探测系统

9.1 用UID作为选择条件

  • 利用把用户id(UID)作为选择条件实现新算法加入:

9.2 使用条件变量

  • 使用前提:

    代码与进程无关;
    希望有一个针对所有情况都能用的机制来控制某个特性。
  • 只需创建一个全局变量作为一个选择开关。

9.3 使用统计量

  • 提供某种机制访问其统计结果。

9.4 重复频率限制

  • 为了避免调试信息发生井喷,可以每隔几秒执行一次操作。

10. 用二分法找出引发罪恶的变更

11. 使用Git进行二分搜索

$ git bisect start  ;进行二分搜索
$ git bisect bad ;引发提供一个出现问题的最高内核版本
$ git bisect bad ;若当前内核版本就是bug的元凶,那不必提供内核版本
$ git bisect good v2.6.28 ;最新可正常运行的内核版本

$ git bisect good ;这个版本正常
$ git bisect bad ;这个版本有异常

12. 当所有努力都失败时:社区

  • Linux内核邮件列表(LKML)

推荐阅读
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了如何清除Eclipse中SVN用户的设置。首先需要查看使用的SVN接口,然后根据接口类型找到相应的目录并删除相关文件。最后使用SVN更新或提交来应用更改。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
author-avatar
手机用户2602932547
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有