Linux内核精髓:精通Linux内核必会的75个绝技

Linux内核精髓:精通Linux内核必会的75个绝技
作 者: 高桥 浩和
出版社: 机械工业出版社
丛编项:
版权说明: 本书为公共版权或经版权方授权,请支持正版图书
标 签: LINUX 操作系统/系统开发 计算机/网络
ISBN 出版时间 包装 开本 页数 字数
未知 暂无 暂无 未知 0 暂无

作者简介

  主编简介高桥 浩和(Hirokazu Takahashi)毕业于北海道大学电子工学系。从VAX全盛时代开始致力于各种UNIX系列操作系统的功能强化和内核调整,以及大规模系统的实时操作系统的设计等。以ISP的服务器构建为契机,开始正式研究Linux。作者简介池田 宗广(Munehiro IKEDA)大学时代,亲眼看到X68000的gcc生成比主流编译器还要快好几倍的代码,因此开始确信免费软件/开源软件的可能性。此后,在历经咖啡店店员、生产技术人员、硬件工程师后,终于开始从事Linux内核开发。这个行业最吸引人的就是能够跨公司甚至跨国界与世界最优秀的技术人员进行交流。现居住在美国,爱好音乐演奏,当过鼓手,也当过主唱,最近几年一直在弹贝斯。不管是作为技术人员还是贝斯手都喜欢做幕后工作,只不过天生就不喜欢半途而废。大岩 尚宏(Naohiro Ooiwa)任职于Miracle Linux株式会社的软件工程师。大学时研究的是类似手机这样使用天线接收无线高频信号的模拟线路。从事Linux开发工作的时候开始深入研究软件。他是《Debug Hacks》的作者,本书是O扲EILLY JAPAN的第二本Hacks系列图书。岛本 裕志(Hiroshi Shimamoto)软件工程师。负责问题分析和调试。主要工作就是在出现故障时,根据日志和核心转储找出问题所在。因此在工作中会经常用到二进制和CPU运行的知识。同时也在论坛中从事过一些关于x86架构和调度程序的活动。目前关注虚拟化方面的活动。竹部 晶雄(Akio Takebe)在Xen、KVM等与虚拟化相关的开源论坛参与开发活动。主要负责IA64架构、RAS系列和PCI pass through的开发。在开源论坛认识了专门研究省电技术的工程师,从而开始对省电方面产生兴趣。现在正使用Ruby on Rails开发云计算相关软件。平松 雅巳(Masami Hiramatsu)Linux内核追踪的相关维护人员。主要工作是对perf和ftrace的动态事件进行维护。也参与了SystemTap的开发,最近热衷于将系统SystemTap的用途从专门用于追踪扩展到游戏编程等。主要使用的是bash和vim,但是因为bash不能用hjkl移动光标,总的来说属于vim用户。喜欢使用Ubuntu和Fedora。现在的研究方向是ARM Linux、Btrfs等。撰稿人简介畑山 大辅(HATAYAMA D...

内容简介

经过近20年的发展,Linux操作系统已经成为当今最成功的开源软件之一,使用广泛,影响深远。随着Linux操作系统功能的不断丰富和完善,Linux内核的源代码也从最初的几万行增加到如今的数百万行,庞大无比,对于Linux内核的研究者和开发者而言,要系统研究Linux内核绝非易事。鉴于此,本书选取了资源管理(CPU、内存、进程等)、文件系统、网络、虚拟化、省电、调试、概要分析、追踪、内核调整等Linux内核的核心主题进行了深入剖析和讲解,总结出了75个能有助于读者深刻理解Linux内核精髓的技巧和最佳实践。

图书目录

编者与作者介绍

主编致辞

前言

第1章 内核入门1

HACK #1 如何获取Linux内核1

HACK #2 如何编译Linux内核7

HACK #3 如何编写内核模块18

HACK #4 如何使用Git22

HACK #5 使用checkpatch.pl检查补丁的格式41

HACK #6 使用localmodconfig缩短编译时间44

第2章 资源管理47

HACK #7 Cgroup、Namespace、Linux容器47

HACK #8 调度策略55

HACK #9 RT Group Scheduling 与RT Throttling59

HACK #10 Fair Group Scheduling62

HACK #11cpuset65

HACK #12 使用Memory Cgroup限制内存使用量68

HACK #13 使用Block I/O控制器设置I/O优先级74

HACK #14 虚拟存储子系统的调整80

HACK #15 ramzswap85

HACK #16 OOM Killer的运行与结构91

第3章 文件系统98

HACK #17 如何使用ext498

HACK #18 向ext4转换101

HACK #19 ext4的调整104

HACK #20 使用fio进行I/O的基准测试111

HACK #21FUSE118

第4章 网络121

HACK #22 如何控制网络的带宽121

HACK #23 TUN/TAP设备126

HACK #24 网桥设备129

HACK #25 VLAN133

HACK #26 bonding驱动程序136

HACK #27 Network Drop Monitor141

第5章 虚拟化147

HACK #28 如何使用Xen147

HACK #29 如何使用KVM153

HACK #30 如何不使用DVD安装操作系统159

HACK #31 更改虚拟CPU分配方法,提高性能161

HACK #32 如何使用EPT提高客户端操作系统的性能166

HACK #33 使用IOMMU提高客户端操作系统运行速度173

HACK #34 使用IOMMU+SR-IOV提高客户端操作系统速度183

HACK #35 SR-IOV带宽控制187

HACK #36 使用KSM节约内存189

HACK #37 如何挂载客户端操作系统的磁盘194

HACK #38 从客户端操作系统识别虚拟机环境200

HACK #39 如何调试客户端操作系统205

第6章 省电213

HACK #40 ACPI213

HACK #41 使用ACPI的 S状态224

HACK #42 使用CPU省电(C、P状态)226

HACK #43 PCI设备的热插拔236

HACK #44 虚拟环境下的省电240

HACK #45 远程管理机器的电源246

HACK #46 USB的电力管理251

HACK #47 显示器的省电254

HACK #48 通过网络设备节省电能260

HACK #49 关闭键盘的LED来省电263

HACK #50 PowerTOP269

HACK #51 硬盘的省电276

第7章 调试282

HACK #52 SysRq键282

HACK #53 使用diskdump提取内核崩溃转储288

HACK #54 使用Kdump提取内核崩溃转储293

HACK #55 崩溃测试297

HACK #56 IPMI看门狗计时器299

HACK #57 NMI看门狗计时器305

HACK #58 soft lockup307

HACK #59 crash命令312

HACK #60 核心转储过滤器326

HACK #61 生成用户模式进程的进程核心转储329

HACK #62 使用lockdep查找系统的死锁335

HACK #63 检测内核的内存泄漏341

第8章 概要分析与追踪346

HACK #64 使用perf tools的概要分析(1)346

HACK #65 使用perf tools的概要分析(2)349

HACK #66 进行内核或进程的各种概要分析353

HACK #67 追踪内核的函数调用360

HACK #68  ftrace的插件追踪器366

HACK #69 记录内核的运行事件371

HACK #70 使用trace-cmd的内核追踪378

HACK #71 将动态追踪事件添加到内核中382

HACK #72 使用SystemTap进行内核追踪388

HACK #73 使用SystemTap编写对话型程序394

HACK #74 SystemTap脚本的重复利用399

HACK #75 运用SystemTap402