网络报文分析利器eBPF简介
所属分类 BPF
浏览量 594
BPF(Berkeley Packet Filter )
1992 伯克利实验室的一篇论文 The BSD Packet Filter: A New Architecture for User-level Packet Capture
这篇论文描述了,BPF 是如何更加高效灵活地从操作系统内核中抓取网络数据包的
Wireshark 和 tcmdump 依赖libpcap库,libpcap库使用 BPF 技术
linux kernle从2.1版本开始支持BPF功能,
在 BPF 实现的基础上,Linux 在 2014 年内核 3.18 版本上实现了 eBPF
eBPF 是 BPF 的增强
eBPF extended Berkeley Packet Filter
对虚拟机做了增强,扩展了寄存器和指令集的定义,提高了虚拟机的性能,可以处理更加复杂的程序
增加了 eBPF maps,这是一种存储类型,可以保存状态信息,从一个 BPF 事件的处理函数传递给另一个,或者保存一些统计信息,从内核态传递给用户态程序。
eBPF在内核中支持JIT即时编译,机器指令和寄存器可以一一对应
增加了Verifier验证器,以保证在内核中执行的字节码是安全的
eBPF 主要应用领域
安全,网络,负载均衡,故障分析,追踪等
云原生领域,Cilium 使用 eBPF 实现了无 kube-proxy 的容器网络
利用eBPF解决iptables带来的性能问题
网络领域,内核态网络包的快速处理和转发,XDP eXpress Data Path
安全领域,通过LSM(Linux Security Module)的 hook 点
eBPF 可以对 Linux 内核做安全监控和访问控制,可参考KRSI(Kernel Runtime Security Instrumentation)的文档
wireshark 抓包
tcpdump使用简介
上一篇
下一篇
fateboard 源码笔记
wireshark 抓包
fate flow 命令行 请求 抓包分析
python3-001 基础语法
python3-002 基本数据类型
python3-003 条件和循环