从 0 到 1:如何用 eBPF 深入监控 Linux 内核?
nanshan 2025-04-26 19:50 24 浏览 0 评论
随着云计算、容器化和微服务架构的兴起,对 Linux 内核的深入监控变得至关重要。传统的监控工具(如 top、strace、tcpdump)虽然实用,但往往受限于性能开销、数据粒度等问题。而 eBPF(Extended Berkeley Packet Filter)提供了一种高效、安全且灵活的方法来深入观察 Linux 内核的运行状态。
本篇文章将从 0 到 1,带你了解 eBPF 的基础概念,并实践如何使用 eBPF 来监控 Linux 内核。
2. 什么是 eBPF?
eBPF 是 Linux 内核中的一个技术,可以在 不修改内核代码 的情况下动态加载和执行程序。它最初用于网络数据包过滤(类似 iptables),但如今已扩展到安全监控、性能分析、系统追踪等领域。
eBPF 的优势
o 高性能:eBPF 在内核态执行,避免了用户态和内核态频繁切换的开销。
o 安全性:eBPF 具有严格的验证机制,确保不会影响系统稳定性。
o 灵活性:无需修改内核代码,即可实时插桩,适用于多种监控需求。
3. eBPF 的应用场景
① 系统监控
o 监控 CPU、内存、磁盘 I/O、网络流量等系统资源使用情况。
o 追踪系统调用(syscall),分析应用程序的行为。
② 性能优化
o 分析长时间运行的进程,优化 CPU 和内存使用。
o 监测磁盘 I/O 和网络流量,定位性能瓶颈。
③ 安全审计
o 记录异常系统调用,检测潜在的攻击行为。
o 监控容器内部的进程活动,增强安全防护。
4. eBPF 实战:用 bcc 监控 Linux 内核
① 安装 eBPF 相关工具
要使用 eBPF,我们可以选择 BCC(BPF Compiler Collection) 作为开发框架。首先,在 Linux 机器上安装 BCC:
# 安装 bcc 工具(Ubuntu/Debian)
sudo apt update
sudo apt install -y bpfcc-tools linux-headers-$(uname -r)
# 安装 bcc 工具(CentOS/Red Hat)
sudo yum install -y epel-release
sudo yum install -y bcc-tools kernel-devel-$(uname -r)
# 验证安装
ls /sys/fs/bpf/
如果 /sys/fs/bpf/ 目录存在,说明 eBPF 运行环境已准备就绪。
② 使用 eBPF 监控进程系统调用
我们使用 execsnoop 这个 eBPF 脚本来监控所有进程的 exec() 调用(即执行新进程):
sudo /usr/sbin/bcc/tools/execsnoop
执行后,你将会看到所有新进程的执行情况,例如:
PCOMM PID PPID RET ARGS
bash 3456 1234 0 /bin/bash
python3 6789 3456 0 script.py
curl 7890 6789 0 https://example.com
这可以用于检测系统中可疑的进程执行情况。
③ 使用 eBPF 监控网络流量
如果你想分析 TCP 连接建立情况,可以使用 tcpconnect 这个 eBPF 工具:
sudo /usr/sbin/bcc/tools/tcpconnect
执行后,你将看到类似如下的输出:
PID COMM LADDR LPORT RADDR RPORT
1234 curl 192.168.1.2 56789 93.184.216.34 443
5678 python3 192.168.1.2 23456 142.251.36.46 443
这有助于分析网络连接情况,防止恶意程序偷偷建立外部连接。
④ 自定义 eBPF 监控脚本
如果我们想监控某个特定进程的 open 系统调用(即文件打开操作),可以编写一个 eBPF 脚本:
from bcc import BPF
# 定义 eBPF 代码
program = """
#include <uapi/linux/ptrace.h>
int trace_open(struct pt_regs *ctx) {
bpf_trace_printk("File opened!\\n");
return 0;
}
"""
# 加载 eBPF 代码
b = BPF(text=program)
b.attach_kprobe(event="sys_open", fn_name="trace_open")
# 打印 eBPF 输出
print("Tracing file open calls... Press Ctrl+C to exit.")
while True:
try:
print(b.trace_readline())
except KeyboardInterrupt:
exit()
这个 eBPF 脚本可以拦截 open 系统调用,并打印日志,适用于文件操作监控。
5. eBPF 的未来
eBPF 目前已经在 Facebook、Google、Netflix、Alibaba 等大规模应用中,用于系统监控、安全防护和性能优化。未来,它将在 自动化运维、容器监控、零信任安全 等领域发挥更大作用。
对于 DevOps 工程师和 Linux 运维人员,掌握 eBPF 监控技能,将成为核心竞争力之一。
6. 总结
o eBPF 是 Linux 内核的一项强大技术,可以在不修改内核代码的情况下实现高效的系统监控。
o eBPF 可以用于系统监控、性能优化和安全审计,广泛应用于云计算和容器化环境。
o 使用 BCC 框架可以快速开发 eBPF 监控工具,例如 execsnoop、tcpconnect 等。
o 掌握 eBPF 能让你在 Linux 运维领域更具竞争力,未来发展潜力巨大。
如果你对 eBPF 感兴趣,可以尝试更多的 eBPF 案例,例如 opensnoop(监控文件打开操作)、biolatency(监控磁盘 I/O 延迟)等。
这篇文章涵盖了 eBPF 从概念到实战的全过程,希望能帮助你更好地理解 Linux 内核监控。如果你觉得有用,欢迎点赞、评论、关注,一起交流技术!
相关推荐
- 轻量级分析利器再升级:解读 DuckDB 1.3.0 新特性
-
DuckDB团队近日正式发布了最新版本——DuckDB1.3.0,代号“Ossivalis”。此次版本以金眼鸭的远古祖先BucephalaOssivalis命名,象征项目在演化和成长过...
- C++跨平台编译的终极奥义:用Docker把环境差异按在地上摩擦
-
"代码在本地跑得飞起,一上服务器就coredump?"——每个C++程序员都经历过的《编译器的复仇》事件!大家好,我是Henry,废话少说,今天来简单谈一下跨平台编译的那些事儿,...
- 全网最全-Version Script以及__asm__((".symver xxx"))使用总结
-
首先提醒一点,一切的前提建立在你的名字必须要mangling,不然无论你写的versionscript还是__asm__都不会起任何效果VersionScript简单用法:这是一个典型例子,这个例...
- Ubuntu 25.04 Beta发布:Linux 6.14内核
-
IT之家3月28日消息,Canonical昨日(3月27日)放出了Beta版Ubuntu25.04系统镜像,代号“PluckyPuffin”,稳定版预估将于2025年...
- 不同平台CRT的区别?什么是UCRT?如何看libc源代码?
-
若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好!CRT运行时库C标准规定例如输入输出函数、字符串函数、内存操作等接口,一般采用C运行时库实现。微软的CRT微软有两套CRT,早期的MS...
- 信创力量,中兴绽放——中兴新支点桌面操作系统安装与使用全攻略
-
原文链接:「链接」Hello,大家好啊,今天给大家带来一篇中兴新支点桌面操作系统安装使用的文章,欢迎大家分享点赞,点个在看和关注吧!中兴新支点桌面操作系统是一款基于Linux内核、面向政企和信创环...
- Linux下安装常用软件都有哪些?做了一个汇总列表,你看还缺啥?
-
1.安装列表MySQL5.7.11Java1.8ApacheMaven3.6+tomcat8.5gitRedisNginxpythondocker2.安装mysql1.拷贝mysql安装文件到...
- 一篇文章解决Linux系统安全问题排查,另配实操环境
-
实操地址:https://www.skillup.host/1/linux/safe/command.md#Linux安全检查排查指南##1.系统账户安全检查###1.1检查异常账户``...
- 程序员必备的学习笔记《TCP/IP详解(一)》
-
为什么会有TCP/IP协议在世界上各地,各种各样的电脑运行着各自不同的操作系统为大家服务,这些电脑在表达同一种信息的时候所使用的方法是千差万别。就好像圣经中上帝打乱了各地人的口音,让他们无法合作一样...
- 《Linux常用命令》(linux的常用命令总结)
-
一、文件与目录操作1.目录导航pwd:显示当前工作目录路径示例:pwd关键词:当前路径、工作目录cd:切换目录示例:cd/home/user#切换到绝对路径cd..#...
- Kubernetes 教程之跟着官方文档从零搭建 K8S
-
前言本文将带领读者一起,参照者Kubernetes官方文档,对其安装部署进行讲解.Kubernetes更新迭代很快,书上、网上等教程可能并不能适用于新版本,但官方文档能.阅读这篇文章你...
- 电脑网卡坏了怎么修复(电脑网卡坏了怎么修复win7系统)
-
当电脑网卡出现故障时,无论是有线网络还是无线网络,都可能无法正常连接。下面从软件、硬件等方面,分步骤为你介绍排查与修复的解决方案。一、初步排查:锁定问题源头检查网络环境将手机、平板等其他设备连接至同一...
- 如何查询电脑/手机的物理地址(如何找手机的物理地址)
-
一、要查询电脑的物理地址(也称为MAC地址),可以按照以下步骤进行操作:1.打开命令提示符(Windows)或终端(Mac):-在Windows上,点击“开始”按钮,搜索“命令提示符”,然后点击打...
- IPv4 无网络访问权限全流程解决方案
-
当设备出现IPv4无网络访问权限问题时,多由网络配置错误、连接故障或服务异常导致。以下提供系统化的排查步骤与解决方案,帮助用户快速定位并修复问题。一、基础故障快速检查1.物理连接确认有线网络:检...
- Python教程(十九):文件操作(python操作文件夹)
-
昨天,我们学习了列表推导式,掌握了Python中最优雅的数据处理方式。今天,我们将学习文件操作—Python中读写文件的基础技能。文件操作是编程中的核心技能,无论是读取配置文件、保存用户数据,还是...
你 发表评论:
欢迎- 一周热门
-
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
手机如何设置与显示准确时间的详细指南
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
一加手机与电脑互传文件的便捷方法FileDash
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
- 最近发表
-
- 轻量级分析利器再升级:解读 DuckDB 1.3.0 新特性
- C++跨平台编译的终极奥义:用Docker把环境差异按在地上摩擦
- 全网最全-Version Script以及__asm__((".symver xxx"))使用总结
- Ubuntu 25.04 Beta发布:Linux 6.14内核
- 不同平台CRT的区别?什么是UCRT?如何看libc源代码?
- 信创力量,中兴绽放——中兴新支点桌面操作系统安装与使用全攻略
- Linux下安装常用软件都有哪些?做了一个汇总列表,你看还缺啥?
- 一篇文章解决Linux系统安全问题排查,另配实操环境
- 程序员必备的学习笔记《TCP/IP详解(一)》
- 《Linux常用命令》(linux的常用命令总结)
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)