经典文章 | paper | 大佬视频 |
---|---|---|
面试题 | 开源项目 | |
️知识体系 | 电子书籍 | 源码下载 |
在我们学习Linux内核之前,我们首先需要掌握以下几点:
1、浅谈Linux内核之CPU缓存
内存管理
1、硬件原理 和 分页管理
2、内存的动态申请和释放
3、进程的内存消耗和泄漏
4、内存与I/O的交换
5、其他工程问题以及调优
6、一文了解,Linux内存管理,malloc、free 实现原理
7、尽情阅读,技术进阶,详解mmap原理
8、浅谈Linux内存管理机制
9、熟读精思,熟读玩味,Linux虚拟内存管理,MMU机制,原来如此也
进程管理
1、Linux进程、线程、调度(一)
2、Linux进程、线程、调度(二)
3、Linux进程、线程、调度(三)
4、Linux进程、线程、调度(四)
5、一文带你,彻底了解,零拷贝Zero-Copy技术
6、进程间通信,管道,socket,XSI(System V)
文件系统
1、Linux 操作系统原理-文件系统(一)
2、Linux 操作系统原理-文件系统(二)
3、Linux文件系统详解
4、磁盘IO那些事
网络协议栈
1、Linux内核网络udp数据包发送(一)
2、Linux内核网络udp数据包发送(二)-UDP协议层分析
3、Linux内核网络UDP数据包发送(三)—IP协议层分析
4、Linux操作系统原理—内核网络协议栈
5、Linux网络栈解剖
6、深入分析Linux操作系统对于TCP IP栈的实现原理与具体过程
7、透过现象看本质,从linux源码角度看epoll
8、驾驭Linux内部网络实现——关键数据结构 sk_buff
设备驱动
1、Linux 总线、设备、驱动模型的探究
2、Linux 设备和驱动的相遇
No. | Title | Translation(参考) | Company |
---|---|---|---|
1 | 《A dataset of feature additions and feature removals from the Linux kernel》 | 《从Linux内核中添加和删除特性的数据集》 | 滑铁卢大学 |
2 | 《A Novel DDoS Floods Detection and Testing Approaches for Network Traffic based on Linux Techniques》 | 《基于Linux技术的网络流量DDoS flood检测与测试方法》 | 大连理工大学软件学院 |
3 | 《A Permission Check Analysis Framework for Linux Kernel》 | 《Linux内核权限检查分析框架》 | 弗吉尼亚理工学院 |
4 | 《An Evaluation of Adaptive Partitioning of Real-Time Workloads on Linux》 | 《Linux下实时工作负载自适应分区的评估》 | Red Hat |
5 | 《Analysis and Study of Security Mechanisms inside Linux Kernel 》 | 《Linux内核内部安全机制分析与研究》 | 北京交通大学计算机与信息技术学院 |
6 | 《Architecture of the Linux kernel》 | 《Linux内核的架构》 | 未知 |
7 | 《Automated Patch Backporting in Linux》 | 《Linux中的自动补丁支持》 | 新加坡国立大学 |
8 | 《Automated Voxel Placement A Linux-based Suite of Tools for Accurate and Reliable Single Voxel Coregistration》 | 《自动化体素放置基于linux的精确可靠的单体素共配准工具套件》 | 韦恩州立大学 |
9 | 《Automatic Rebootless Kernel Updates》 | 《自动重启内核更新》 | 麻省理工学院 |
10 | 《Communication on Linux using Socket Programming in ‘C’》 | 《基于C语言套接字编程的Linux通信》 | 印度北阿坎德邦现代技术学院计算机科学与信息技术系 |
11 | 《Compatibility of Linux Architecture for Diskless Technology System》 | 《Linux体系结构对无磁盘技术系统的兼容性》 | 台南科技大学电气工程学院 |
12 | 《Concurrency in the Linux kernel》 | 《Linux内核中的并发性》 | 伦敦大学 |
13 | 《Container-based real-time scheduling in the Linux kernel》 | 《Linux内核中基于容器的实时调度》 | 未知 |
14 | 《Crash Consistency Test Generation for the Linux Kernel》 | 《Linux内核的崩溃一致性测试生成》 | 德克萨斯大学奥斯汀分校 |
15 | 《Designing of a Virtual File System》 | 《虚拟文件系统的设计》 | 未知 |
16 | 《Efficient Formal Verification for the Linux Kernel》 | 《Linux内核的有效正式验证》 | RETIS实验室 |
17 | 《Exploiting Uses of Uninitialized Stack Variables in Linux Kernels to Leak Kernel Pointers》 | 《利用Linux内核中未初始化的堆栈变量泄漏内核指针》 | 亚利桑那州立大学 |
18 | 《Hybrid Fuzzing on the Linux Kernel》 | 《Linux内核的混合Fuzzing》 | 俄勒冈州立大学 |
19 | 《In-Process Memory Isolation for Modern Linux Systems》 | 《面向现代Linux系统的进程内内存隔离》 | 罗格斯大学 |
20 | 《Introduction to the Linux kernel challenges and case studies》 | 《介绍Linux内核的挑战和案例研究》 | 马德里康普顿斯大学 |
21 | 《Kernel Mode Linux Toward an Operating System Protected by a Type Theory》 | 《面向类型理论保护的操作系统的内核模式Linux》 | 东京大学 |
22 | 《Linux Kernel development》 | 《Linux内核开发》 | 怀卡托大学 |
23 | 《Linux Kernel Transport Layer Security》 | 《Linux内核传输层安全》 | |
24 | 《Linux kernel vulnerabilities State-of-the-art defenses and open problems》 | 《Linux内核漏洞最新的防御和开放问题》 | 麻省理工学院 |
25 | 《Linux Kernel Workshop Hacking the Kernel for Fun and Profit》 | 《Linux内核研讨会黑客内核的乐趣和利润》 | IBM |
26 | 《Linux Network Device Drivers an Overview》 | 《Linux网络设备驱动程序概述》 | 印度理工学院 |
27 | 《Linux Physical Memory Page Allocation》 | 《Linux物理内存页分配》 | 未知 |
28 | 《Linux Random Number Generator – A New Approach》 | 《Linux随机数生成器-一种新的方法》 | 未知 |
29 | 《Machine Learning for Load Balancing in the Linux Kernel》 | 《Linux内核负载平衡的机器学习》 | 伊利诺伊大学 |
30 | 《Performance of IPv6 Segment Routing in Linux Kernel》 | 《Linux内核下的IPv6段路由性能》 | Cisco |
31 | 《Professional Linux® Kernel Architecture》 | 《专业的Linux®内核架构》 | Wolfgang Mauerer |
32 | 《Research of Performance Linux Kernel File Systems》 | 《高性能Linux内核文件系统的研究》 | 乌拉尔国立技术大学 |
33 | 《Resource Management for Hardware Accelerated Linux Kernel Network Functions》 | 《硬件加速Linux内核网络功能的资源管理》 | 积云网络 |
34 | 《Rethinking Compiler Optimizations for the Linux Kernel An Explorative Study》 | 《重新思考Linux内核的编译器优化——探索性研究》 | 北京大学电子工程与计算机学院 |
35 | 《Securing the Linux Boot Process From Start to Finish》 | 《从开始到结束保护Linux引导过程》 | 奥地利波尔顿应用科学大学 |
36 | 《Security Applications of Extended BPF Under the Linux Kernel》 | 《Linux内核下扩展BPF的安全应用》 | 卡尔顿大学计算机科学学院 |
37 | 《Simple and precise static analysis of untrusted Linux kernel extensions》 | 《简单和精确的静态分析不可信的Linux内核扩展》 | VMware |
38 | 《Speeding Up Linux Disk Encryption》 | 《加快Linux磁盘加密》 | 未知 |
39 | 《Stateless model checking of the Linux kernel’s hierarchical read-copy-update (tree RCU)》 | 《Linux内核的分层read-copy-update (tree RCU)的无状态模型检查》 | 雅典国立技术大学 |
40 | 《Survey Paper on Adding System Call in Linux Kernel 3.2+ & 3.16》 | 《关于在Linux内核3.2+ & 3.16中添加系统调用的调查报告》 | 北阿坎德邦技术大学Shivalik工程学院计算机科学与工程 |
41 | 《The benefits and costs of writing a POSIX kernel in a high-level language》 | 《用高级语言编写POSIX内核的好处和成本》 | 麻省理工学院 |
42 | 《The real-time Linux kernel a Survey on PREEMPT_RT》 | 《实时Linux内核PREEMPT_RT综述》 | 米兰理工大学 |
43 | 《Trace-Based Analysis of Locking in the Linux Kernel》 | 《基于跟踪的Linux内核锁定分析》 | 奥斯纳布吕克大学 |
44 | 《Tracing Network Packets in the Linux Kernel using eBPF》 | 《使用eBPF跟踪Linux内核中的网络包》 | 圣彼得堡国立大学 |
45 | 《TRACING THE WAY OF DATA IN A TCP CONNECTION THROUGH THE LINUX KERNEL》 | 《通过Linux内核跟踪TCP连接中的数据方式》 | 加纳马尼理工学院 |
46 | 《Understanding Linux Kernel》 | 《了解Linux内核》 | 未知 |
47 | 《Understanding Linux Malware》 | 《了解Linux的恶意软件》 | Cisco |
48 | 《Using kAFS on Linux for Network Home Directories》 | 《在Linux上使用kfs用于网络主目录》 | 密歇根大学 |
49 | 《Verification of tree-based hierarchical read-copy update in the Linux kernel》 | 《Linux内核中基于树的分层读拷贝更新的验证》 | 牛津大学 |
50 | 《XDP test suite for Linux kernel》 | 《Linux内核的XDP测试套件》 | 马萨里克大学 |
1、Linux Kernel Network Drivers - Classification(Linux内核网络驱动程序)百度网盘:qdt5
2、Linux Kernel Development(Linux内核开发)百度网盘:vg1u
3、The mind behind Linux(Linux背后的思想)百度网盘:zgnu
4、Linux Systems Performance(Linux系统性能)百度网盘:9qom
5、Network Driver Interfaces(网络驱动程序接口)百度网盘:xpke
6、Selective module compilation in mainline kernel(在主线内核中编译可选模块):百度网盘:l56j
7、Linux System Programming 6 Hours Course(Linux系统编程6小时课程)百度网盘:hc2d
8、Threads and Thread Handing(线程和线程处理)百度网盘:erxm
9、Learning the Linux Kernel with tracing(通过跟踪学习Linux内核)百度网盘:066g
10、How to Apply a Patch to the Linux Kernel Stable Tree(如何将补丁应用到Linux内核稳定树)百度网盘:955e
11、Linux Kernel Programming(Linux内核编程- atomic_t数据类型-原子变量和api)百度网盘:njt0
12、Kernel Recipes 2017 - 性能优化大牛Brendan Gregg 百度网盘:lrex
面试题一
1、什么是Linux?
2、Unix和Linux有什么区别?
3、什么是 Linux 内核?
4、Linux的基本组件是什么?
5、Linux 的体系结构
6、BASH和DOS之间的基本区别是什么?
7、Linux 开机启动过程?
8、Linux系统缺省的运行级别?
9、Linux 使用的进程间通信方式?
10、Linux 有哪些系统日志文件?
11、Linux系统安装多个桌面环境有帮助吗?
12、什么是交换空间?
13、什么是root帐户?
14、什么是LILO?
15、什么是BASH?
16、什么是CLI?
17、什么是GUI?
18、开源的优势是什么?
19、简单 Linux 文件系统?
20、Linux 的目录结构是怎样的?
21、什么是 inode ?
22、什么是硬链接和软链接?
23、RAID 是什么?
24、一台 Linux 系统初始化环境后需要做一些什么安全工作?
25、什么叫 CC 攻击?什么叫 DDOS 攻击?
26、什么是网站数据库注入?
27、Shell 脚本是什么?
28、可以在 Shell 脚本中使用哪些类型的变量?
29、Shell 脚本中 if
语法如何嵌套?
30、Shell 脚本中 case
语句的语法?
31、Shell 脚本中 for
循环语法?
32、Shell 脚本中 while
循环语法?
33、如何使脚本可执行?
34、在 Shell 脚本如何定义函数呢?
35、判断一文件是不是字符设备文件,如果是将其拷贝到 /dev
目录下?
36、添加一个新组为 class1 ,然后添加属于这个组的 30 个用户,用户名的形式为 stdxx ,其中 xx 从 01 到 30 ?
37、写一个 sed 命令,修改 /tmp/input.txt
文件的内容?
38、用户进程间通信主要哪几种方式?
39、通过伙伴系统申请内核内存的函数有哪些?
40、Linux 虚拟文件系统的关键数据结构有哪些?(至少写出四个)
41、对文件或设备的操作函数保存在那个数据结构中?
42、Linux 中的文件包括哪些?
43、创建进程的系统调用有那些?
44、调用 schedule()进行进程切换的方式有几种?
45、Linux 调度程序是根据进程的动态优先级还是静态优先级来调度进程的?
46、进程调度的核心数据结构是哪个?
47、如何加载、卸载一个模块?
48、模块和应用程序分别运行在什么空间?
49、Linux 中的浮点运算由应用程序实现还是内核实现?
50、模块程序能否使用可链接的库函数?
51、TLB 中缓存的是什么内容?
52、Linux 中有哪几种设备?
53、字符设备驱动程序的关键数据结构是哪个?
54、设备驱动程序包括哪些功能函数?
55、如何唯一标识一个设备?
56、Linux 通过什么方式实现系统调用?
57、Linux 软中断和工作队列的作用是什么?
58、Linux开机启动过程?
59、Linux系统缺省的运行级别
60、Linux系统是由那些部分组成?
61、硬链接和软链接有什么区别?
62、如何规划一台Linux主机,步骤是怎样?
63、查看系统当前进程连接数?
64、如何在/usr目录下找出大小超过10MB的文件?
65、添加一条到192.168.3.0/24的路由,网关为192.168.1.254?
66、如何在/var目录下找出90天之内未被访问过的文件?
67、如何在/home目录下找出120天之前被修改过的文件?
68、在整个目录树下查找文件“core”,如发现则无需提示直接删除它们。
69、有一普通用户想在每周日凌晨零点零分定期备份/user/backup到/tmp目录下,该用户应如何做?
70、每周一下午三点将/tmp/logs目录下面的后缀为*.log的所有文件rsync同步到备份服务器192.168.1.100中同样的目录下面,crontab配置项该如何写?
71、找到/tmp/目录下面的所有名称以"_s1.jpg"结尾的普通文件,如果其修改日期在一天内,则将其打包到/tmp/back.tar.gz文件中
72、配置mysql服务器的时候,配置了auto_increment_increment=3,请问这里的3意味着什么?
73、详细说明keepalived的故障切换工作原理
No. | Project | Introduction |
---|---|---|
1 | esp8089 | ESP8089 WiFi芯片的Linux内核模块驱动程序 |
2 | fibdrv | 计算斐波那契数列的Linux内核模块 |
3 | exfat-linux | 这个用于Linux内核的exFAT文件系统模块是三星最新的Linux主线的exFAT驱动程序的后端端口。这个项目可以用于日常Linux用户,只需简单地做make && make install。Ubuntu用户可以简单地添加一个PPA并开始使用它,甚至不需要下载代码。这也可以直接插入到现有的Linux内核源代码中,以内联地构建文件系统驱动程序,这对Android内核开发人员应该很有用。 |
4 | ipt-netflow | 适用于 Linux 的高性能 NetFlow v5、v9、IPFIX 流数据导出模块核心。创建用于高吞吐量网络中的 linux 路由器。 |
5 | buildKernelAndModules | 在NVIDIA Jetson Nano Developer Kit上构建Linux内核和模块 |
6 | kernel-modules-hook | 使Arch Linux在内核升级后完全功能 |
7 | rfm12b-linux | HopeRF公司生产的RFM12B和RFM69CW数字射频模块的Linux内核驱动程序。它的目标是提供SPI接口的嵌入式Linux板。 |
8 | khttpd | khttpd是一个实验性的HTTP服务器,实现为Linux内核模块。服务器默认端口为8081,但是可以使用命令行参数port=?当您准备加载内核模块时。 |
9 | Kernel_Rootkit | Kernel_Rootkit是一种特殊类型的恶意软件,它通过修改操作系统内核来向用户和系统管理员隐藏自己的存在。rootkit是一个内核模块——一个动态加载到内核中的库。 |
10 | ktls | Linux内核传输层安全模块 |
11 | frdev | 一个高效的ip黑/白名单防火墙(作为一个linux内核模块)。 |
12 | HomaModule | 一个实现了Homa传输协议的Linux内核模块。 |
13 | PCRE | Linux内核模块&PCRE文本搜索引擎 |
14 | acpi_call | 一个内核简单模块,允许您通过将方法名称后跟参数写入/proc/ ACPI /call来调用ACPI方法。 |
13 | Linux Modules | 这是一个管理Linux内核模块的工具。它是modprobe的一个替代方案,支持列出、添加和删除模块,以及显示模块上的信息。 |
14 | LiME | 一个可加载内核模块(LKM),它允许从Linux和基于Linux的设备(如Android)获取易失性内存。这使得LiME独一无二,因为它是Android设备上第一个允许全内存捕获的工具。它还在获取过程中最小化了用户和内核空间进程之间的交互,这使得它能够生成比其他为Linux内存获取而设计的工具更可靠的内存捕获。 |
15 | kplugs | KPlugs是一个Linux内核模块,它提供了在Linux内核中动态执行脚本的接口。 |
16 | rapiddisk | 一个高级Linux RAM驱动器和缓存内核模块。动态分配RAM作为块设备。使用它们作为独立的磁盘驱动器,甚至将它们映射为缓存节点到较慢的本地磁盘驱动器。 |
17 | forge_socket | Linux内核模块,用于从用户空间检查/修改TCP套接字状态 |
18 | CCKiller | Linux轻量级CC攻击防御工具脚本 |
19 | libNetGo | Linux网络分析工具 |
20 | wgcloud | linux运维监控工具,支持系统信息,内存,cpu,温度,磁盘空间及IO,硬盘smart,系统负载,网络流量,进程等监控,API接口,大屏展示,拓扑图,端口监控,docker监控,日志文件监控,数据可视化,webSSH工具,堡垒机(跳板机) |
21 | hookso | hookso是一个Linux动态链接库的注入修改查找工具,用来修改其他进程的动态链接库行为。 |
22 | LinuxPerformanceTools | Linux性能监控工具 |
23 | jon | jon 是一款Linux系统攻防工具箱,包含扫描,入侵,痕迹清理,木马,网站测试等各种黑客工具。 |
24 | perf-tools | 用于Linux ftrace和perf_events(也就是“perf”命令)的各种开发中且不受支持的性能分析工具。ftrace和perf都是核心的Linux跟踪工具,包含在内核源代码中。您的系统可能已经有了ftrace,而perf通常只是一个添加包(参见先决条件)。 |
25 | FlameGraph | 火焰图形可视化分析器 |
26 | bcc | BCC 是一个用于创建高效内核跟踪和操作程序的工具包,包括几个有用的工具和示例。它利用了扩展 BPF(伯克利数据包过滤器),正式名称为 eBPF,这是首次添加到 Linux 3.15 的新功能。BCC 使用的大部分内容都需要 Linux 4.1 及更高版本。 |
27 | fhe-toolkit-linux | IBM Linux的完全同态加密(FHE)工具包被打包为Docker容器,这使得开始和试验完全同态加密技术变得更容易。 |
28 | linux-smart-enumeration | 用于渗透测试的Linux枚举工具和具有冗长级别的ctf |
29 | gpu-monitoring-tools | Linux上监视NVIDIA gpu的工具 |
30 | linux-inject | 将共享对象注入Linux进程的工具 |
31 | ntttcp-for-linux | 一个Linux网络吞吐量多线程基准测试工具 |
32 | linux-pentest | Linux穿透测试工具 |
《Linux内核完全注释V3.0书签版》
《Linux命令行大全 - 绍茨 (william E.shotts)》
《Linux命令速查手册》
《Linux就该这么学》
《Linux性能优化大师》
《Linux环境编程:从应用到内核》
《Linux集群和自动化运维 余洪春》
《Linux驱动程序开发实例(第2版)》
《Linux高级程序设计(第3版)》
《构建高可用Linux服务器(第4版)》
《深入了解Linux内核》
Linux内核主要由 进程管理、内存管理、设备驱动、文件系统、网络协议栈 外加一个 系统调用。
源码组织结构
️ Linux内核知识体系
内存管理(文章直达 )(论文直达 )(视频直达 )(面试题直达 )(内核项目直达 )
文件系统(文章直达 )(论文直达 )(视频直达 )(面试题直达 )(内核项目直达 )
进程管理(文章直达 )(论文直达 )(视频直达 )(面试题直达 )(内核项目直达 )
网络协议栈(文章直达 )(论文直达 )(视频直达 )(面试题直达 )(内核项目直达 )
设备驱动(文章直达 )(论文直达 )(视频直达 )(面试题直达 )(内核项目直达 )