百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

从 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__((&quot;.symver xxx&quot;))使用总结

首先提醒一点,一切的前提建立在你的名字必须要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中读写文件的基础技能。文件操作是编程中的核心技能,无论是读取配置文件、保存用户数据,还是...

取消回复欢迎 发表评论: