读书笔记(chapter18)
调试
18.1准备开始
18.2内核中的bug
1.从隐藏在源代码中的错误到展现在目击者面前的bug,往往是经历一系列连锁反应的事件才可能触发的
18.3通过打印来调试
1.健壮性
健壮性是printk()函数最容易让人们接受 一个特质;而且调用者连锁都不必使用
核心硬件部分的黑客依靠此时能够工作的硬件设备与外界通信;绝大部分人对此都不会感兴趣的。
2.日志等级
printk()与printf()最主要区别的就是前者可以指定一个日志级别。内核根据一个级别来判断是否在终端上打印消息
现在默认等级是kern_warning。由于这个默认值将来存在变化的可能性,所以还是应该给自己的消息指定一个记录等级。
3.记录缓冲区
而环形缓冲区的唯一缺点——可能会丢失消息,但是与简单性与健康性的好处相比,这点代价是值得的;
4.syslogd和klogd
在启动klogd的时候,可以通过指定 -c标志来改变终端的记录等级
5.从printf()到printk()的转换
18.4oops
如果oops在中断上下文时,内核根本无法继续,会陷并入混乱。如果oops在idle进程(pid为0)或者init进程(pid为1),结果同样的系统陷入混乱,因为内核缺了这两个重要的进程根本无法工作;内核会杀死该进程并尝试着继续执行
1.ksymoops oops可以说是一个经过解码的oops,内存地址都转换成了它们对应的函数,这需要调用ksymoops命令,并且还必须提供编译内核时产生的system.map
ksymoop saved_opps.txt
2.kallsyms
现场已经无须使用ksymoops工具了,开发版的2.5版内内核引入了kallsyms特性,它可以通过定义于config_kallsyms配置选项启用;
18.5
最有用的一个是sleep-inside-spinlock checking(自旋锁内睡眠选项),这些选项确实能完成不少调试工作.
内核提供一个原子操作计数器。它可以被配置成一旦在原子操作过程中进程进入睡眠或者一些可能引起睡眠的操作。这种调试方法捕获了大量bug
18.6
1.内核调用最常用的是bug()和bug_on();当被调用的时候,它们会引发oops,导致栈的回溯和错误信息的打印。这些声明会导致oops跟硬件的体系结构是相关的。可以用panic()引发更严重的错误;只需要在终端上打印一下栈的回溯信息来帮助调试;
18.7
1.当该功能被启用的时候,无论内核处于什么状态,都可以通过特殊的组合键跟内核进行通信。
2.输入sysrq-h获取一份可用的选项列表;sysrq-u卸载所有的文件系统,sysrq-b重启设备;
18.8
1.gdb(有很多局限性)
gdb_vmlinux /proc/kcore
2.kgdb
18.9
1用UID作为选择条件
2使用条件变量
3使用统计量
4重复频率限制
18.10
1.使用git二分搜索
2.从记录日志到git二分查找法.
读书笔记(chapter18)的更多相关文章
- 读书笔记汇总 - SQL必知必会(第4版)
本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...
- 读书笔记--SQL必知必会18--视图
读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...
- 《C#本质论》读书笔记(18)多线程处理
.NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...
- C#温故知新:《C#图解教程》读书笔记系列
一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...
- C#刨根究底:《你必须知道的.NET》读书笔记系列
一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...
- Web高级征程:《大型网站技术架构》读书笔记系列
一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...
- LOMA280保险原理读书笔记
LOMA是国际金融保险管理学院(Life Office Management Association)的英文简称.国际金融保险管理学院是一个保险和金融服务机构的国际组织,它的创建目的是为了促进信息交流 ...
- 《3D Math Primer for Graphics and Game Development》读书笔记2
<3D Math Primer for Graphics and Game Development>读书笔记2 上一篇得到了"矩阵等价于变换后的基向量"这一结论. 本篇 ...
- 《3D Math Primer for Graphics and Game Development》读书笔记1
<3D Math Primer for Graphics and Game Development>读书笔记1 本文是<3D Math Primer for Graphics and ...
- 《More Effective C#》读书笔记
<More Effective C#>这本书,大概是四年前看完的,但只整理了一部分读书笔记,后面有时间的话,会陆续补充的. More Effective C# :使用泛型 More Eff ...
随机推荐
- django复习-3-请求与响应
一.请求request 前端向后端传递参数有几种方式? 提取URL的特定部分,如/weather/beijing/2018,可以在服务器端的路由中用正则表达式截取: "http://127. ...
- [Python] 同时安装了python2和python3时,pip命令该如何使用?
当python2和python3同时安装windows上时,它们对应的pip都叫pip.exe,所以不能够直接使用 pip install 命令来安装软件包. 而是要使用启动器py.exe来指定pip ...
- Mapreduce运行过程分析(基于Hadoop2.4)——(二)
4.3 Map类 创建Map类和map函数.map函数是org.apache.hadoop.mapreduce.Mapper类中的定义的,当处理每一个键值对的时候,都要调用一次map方法,用户须 ...
- PReLU与ReLU
PReLU激活函数,方法来自于何凯明paper <Delving Deep into Rectifiers:Surpassing Human-Level Performance on Image ...
- persistence_timeout ,域名请求登录后一操作即被踢出,,KeepAlive,lvs
virtual_server *.*.*.* 80 { delay_loop 6 lb_algo wrr lb_kind DR persistence_timeout 120 protocol TCP ...
- Android 写一个Activity之间来回跳转的全局工具类(主要是想实现代码的复用)
废话不多说了,直接上代码,相信大家都能看得懂的. 一.主要工具类 package com.yw.chat.utils; import android.app.Activity; import andr ...
- kubernetes 资源请求和限制
1. spec: containers: - name: example resources: requests: ...
- 计算机视觉-sift(1)原理
1999年由David Lowe首先发表于计算机视觉国际会议(International Conference on Computer Vision,ICCV),2004年再次经David Lowe整 ...
- DQN(Deep Reiforcement Learning) 发展历程(二)
目录 动态规划 使用条件 分类 求解方法 参考 DQN发展历程(一) DQN发展历程(二) DQN发展历程(三) DQN发展历程(四) DQN发展历程(五) 动态规划 动态规划给出了求解强化学习的一种 ...
- gcc 动态编译 动态库路径
gcc 动态编译(共享库) 动态编译的可执行文件需要附带一个的动态链接库,在执行时,需要调用其对应动态链接库中的命令优点:体积小,编译快缺点:依赖性高 代码如下: [root@74-82-173-21 ...