Ftrace公开课:学优化,学内核(限50人)
01
讲师介绍
谢欢,大家可以叫我Jeff, 我目前就职于某国际知名linux发行版开源公司, 热衷于linux内核。我平时把linux内核源码当小说一样阅读学习,也一直把能给linux社区贡献更多有质量的代码而努力.
最近给Linux内核提交了系列补丁objtrace,截至目前有了kprobe maintainer的
Tested-by 和 Reviewed-by.
Tested-by: Masami Hiramatsu <mhiramat@kernel.org>
Reviewed-by: Masami Hiramatsu <mhiramat@kernel.org>
以下是最新patch objtrace源码和邮件列表讨论:
https://github.com/x-lugoo/linux/tree/objtrace-v9
https://lore.kernel.org/all/20220204035644.734878-1-xiehuan09@gmail.com/
02
课程背景
2022年我们走访了华东的芯片、方案、手机、汽车、云计算公司,所有的企业都在向我反馈,能不能帮我们找到好的内核和内核性能优化工程师。我发现大量的企业被困在一个怪圈里,一方面自己的人被其他企业挖走,另外一方面自己又在用猎头挖其他公司的人。由于芯片和电动汽车行业都处在底层软件工程师需求结构性不匹配的情况,行业里薪资大幅度上涨,企业不得不陷入恶性人才竞争。挖人能解眼前问题,但是无法解决企业研发和产品的连续性。基于此我们决定开设这门课程,帮助企业培养自己的底层软件人才。
学内核好比爬珠穆朗玛峰,有南坡和北坡两条路。北坡难爬,这就好比看源码。南坡相对好爬,这就好比使用trace工具,能够更好理解内核的机制。Ftrace就是这些工具中的代表。
深入去分析Linux内核的机制,掌握调试跟踪内核的工具也必不可少,比如ftrace、trace-cmd、kernelshark、perf等。尤其是ftrace提供了两种机制,第一种是动态插入函数,第二种是静态插入函数,其它所有的功能都是基于两者的演变。
Ftrace演变的花样非常多,查看执行流,执行时间,是基于第一种, 基于第二种演变出了event, event可以过滤,可以触发其它的事件,而且第一种和第二种可以结合,变化又非常多。
俗话说,工欲善其事必先利其器,熟练掌握这些工具的使用会让我们优化工作更高效。ftrace是一个很强大的调试工具,除了常用的函数跟踪器能让我们轻松知道一个函数的执行耗时之外,它强大的event机制,更是可以直接让我们在驱动或者内核中添加跟踪点,输出内核执行过程中的各类数据,让我们轻松洞察内核的执行过程。
Ftrace作为trace工具的代表,上擎性能优化,中建可观测性,下筑安全之底。不仅仅是学习内核的工具,还是一个优秀的生产工具。我们希望通过开设这门理论加实践的课程,让学员尽快掌握Ftrace工具,并将其快速用到性能优化等实际生产场景中。
03
课程介绍
学员反馈:
老师是少有的对ftrace,bpf了解原理很精通的人
为什么要学Ftrace,做底层,职业生命更长点
加薪,以阿里为例会Ftrace能够做优化的人,薪资大概可以在100万左右
赶紧让我学习一下ftace,不然就是运维背锅侠
ftrace抓事件,突然死机后有啥办法搞出trace日志吗?
我有内核崩溃kdump,有些崩溃我还不是很看得懂
我一般就是看懂硬件的故障,太复杂的就不行了
平常分析io延迟,判断是不是盘有问题,就用ftrace如何跟踪下centos 上面dns解析过程。
perf工具是基于ftrace的机制 来实现的吧
我用火焰图分析mysql high cpu 效果不错,但是io不太好分析
ftrace侧重全局,perf侧重某个进程、某个cpu的采样和分析,ebpf侧重更细粒度的数据采样和分析
讲师说:
在我仔细研究Linux内核中的ftrace之后,发现ftrace中的各个tracers的作用一直被人们严重低估了, 比如我们会花了大量的时间去理解Linux内核中的一块代码,然后猜测可能的执行流, 但是ftrace会首先直接告诉你整个执行流,然后你再去查看代码,这样无论从效率和准确度来讲都是极大的提升。
对于任意一个函数,想要知道它是否执行了,或者想知道它的函数参数,函数返回值,函数的执行时间,函数向上的执行流,函数向下的执行流,甚至任意两个函数之间的执行流,ftrace都能很好的支持。重要的是所有函数都能这样结合起来使用,还有更加重要的是函数可以跟事件结合起来,事件可以过滤可以触发其它的事件和tracers. 这样就衍生出了无限的可能性。
本课程的设计宗旨是让学员站在设计者的角度来理解ftrace,明白各个tracers为什么这样设计和整个发展脉络,进而更加灵活地使用它以辅助我们的实际工程项目和研究学习,也可以激发学员进而迸发出更加先进的trace功能为整个Linux内核社区做贡献。本课程更加偏向于理解设计思想和使用,如果想了解源代码级别的实现,可以参考我在阅码场平台的视频课程
《Linux内核tracers的实现原理与应用》。
04
课程收益
从根上解决企业Linux底层人员难找的问题,自己培养骨干工程师。
加快问题定位,提高研发效率,加快产品研发上市。
强调动手,以Ftrace为抓手学习内核
以Ftrace为抓手打通软硬件任督二脉:IO和中断
使用Ftrace做性能分析和性能优化
通过案例,学习使用Ftrace分析和定位问题的技巧
Ftrace设计思想和案例分析
05
课程受众
Linux内核态程序员
想探索内核层的用户态程序员
Linux内核爱好者
运维人员
嵌入式开发人员
网络设备研发
内核网络模块开发人员
06
课程大纲
第一部分 实验课程 (2小时) | 1. ftrace总体介绍 2. function tracer 3. 查看函数是否执行 4. 查看函数向上的调用栈(堆栈) 5. set_ftrace_filter一招制胜 6. 练习查看函数是否执行和获取对应的堆栈 |
第二部分 (2小时) | 7. function_graph tracer 8. 查看函数执行时间 9. 查看函数向下的调用栈 10. 同时查看函数向上和向下的调用栈 11. 练习查看函数的执行时间和向下的调用栈 |
第三部分 (2小时) | 12. kprobe event 13. trace event 14. kprobe/tracepoint与event结合 15. probes 与event 结合 16. vfs与event结合 17. event filter 18. event trigger 19. 练习kprobe event和trace event的使用 |
第四部分 (2小时) | 20. function tracer 21. Function graph tracer 22. wakeup 23. blk 24. 练习各种tracer的使用 |
第五部分 (2小时) | 25. ftrace联合大演练之组合的魔力 26. 中断延迟 27. 信号处理 28. 使用ftrace探索poll select epoll io_uring |
第六部分 | 29. 学习成果评估与模拟面试 |
03
课程定价
4000元/人(限50人,购买过阅码场Ftrace视频课程用户优先,先到先得,新用户免费获赠线上视频课程。)
购买了Ftrace视频课程的用户直接按照视频课程价格减免。
每推荐一人购买,自己减200元;推荐公司购买(15人起)免1人费用。
没学会,不满意可以免费继续参加下一次公开课。
完成学业的奖励:终身个人工作推荐。
免费企业招聘发布N次。(企业,5个报名人数1次。)
拟于4/5/6月底开公开课,预报名阶段收200元预报名费,早鸟100元抵200元。