0

0

Linux bpftool prog tracelog / prog profile 的 eBPF 程序加载与跟踪

舞夢輝影

舞夢輝影

发布时间:2026-02-22 15:01:02

|

563人浏览过

|

来源于php中文网

原创

tracelog 看不到 ebpf 日志需检查 bpf_trace_printk 是否启用:确认内核配置 config_bpf_trace_printk=y/m,运行时开关 /proc/sys/kernel/bpf_trace_printk=1,并确保 tracing 已开启。

linux bpftool prog tracelog / prog profile 的 ebpf 程序加载与跟踪

tracelog 看不到 eBPF 程序日志?检查 bpf_trace_printk 是否被禁用

默认情况下,bpftool prog tracelog 只能显示由 bpf_trace_printk 输出的日志,但这个 helper 在内核编译时可能被关闭,或运行时被 sysctl 限制。

实操建议:

  • 确认内核配置:grep CONFIG_BPF_TRACE_PRINTK /boot/config-$(uname -r),必须为 ym
  • 检查运行时开关:cat /proc/sys/kernel/bpf_stats_enabled(旧内核)或更常见的是 /proc/sys/kernel/bpf_trace_printk(5.15+),值为 1 才允许输出
  • bpf_trace_printk 是调试用 helper,不支持格式化字符串中的浮点、宽字符、指针解引用;只认 %s(需传入内核地址)、%d/%x 等基础类型
  • 日志走 trace_printk 子系统,需确保 tracing 已启用:echo 1 > /sys/kernel/tracing/events/bpf_trace/bpf_trace_printk/enable

profile 显示 0% CPU 占用?确认程序是否真在运行且有足够事件触发

bpftool prog profile 依赖 perf 采样,它统计的是 eBPF 程序执行时的 CPU 时间占比。如果看到全零或极低数值,大概率不是工具问题,而是程序根本没跑起来。

实操建议:

  • 先用 bpftool prog list 确认程序状态是 running,不是 errorloaded(未 attach)
  • 检查 attach 点是否生效:比如 tc 类程序要看 tc filter showtracepoint 类要看对应 tracepoint 是否已 enable(/sys/kernel/tracing/events/.../enable
  • perf 采样频率默认较低(~100Hz),短时高频小函数容易漏采;可加 -F 1000 提高频率,但会增加开销
  • profile 不统计 verifier 时间、map 查找失败开销、或因 tail_call 跳转导致的间接调用——这些都算在 caller 里

加载失败报 “invalid bpf_context access”?多半是 BTF 不匹配或校验器版本差异

eBPF 程序加载失败时,bpftool prog load 报的这类错误,往往不是代码写错,而是内核对上下文结构体的视图和你编译时用的 BTF 不一致。

VisionStory
VisionStory

AI视频、直播、视频播客

下载

实操建议:

  • bpftool btf dump file /sys/kernel/btf/vmlinux format c 看当前内核实际暴露的 struct pt_regsstruct sk_buff 等字段偏移,对比你本地 vmlinux.h 或 libbpf 生成的 BTF
  • 如果你用 clang -target bpf 直接编译,务必加 -g 并确保 libbpf 版本 ≥ 1.2,否则 BTF 信息缺失会导致上下文访问被拒
  • 某些字段(如 skb->data)在不同内核版本中可能是 union 成员或宏封装,直接取地址会触发校验失败;应改用 bpf_probe_read_kernel 安全读取
  • 使用 bpftool prog load ... verbose 可看到 verifier 拒绝的具体指令和寄存器状态,比单纯看错误码有用得多

tracelog 和 profile 数据不一致?别混用两种跟踪路径

tracelog 是同步打点,profile 是异步采样,二者机制完全不同,数据天然不可比。拿 tracelog 的调用频次去验证 profile 的 CPU 占比,就像拿秒表测汽车油耗。

实操建议:

  • tracelog 适合验证逻辑路径是否走到、参数是否符合预期;但每条日志带来 ~1μs 开销,高频打点会显著拖慢程序甚至触发限流(/proc/sys/kernel/bpf_stats_enabled 也会关掉它)
  • profile 只反映 CPU 时间分布,对纯内存操作、map 查找、或被抢占挂起的程序不敏感;若程序大部分时间在等锁或 sleep,profile 会低估其真实影响
  • 真正想定位性能瓶颈,应该组合使用:bpftool prog profile 找热点函数 → bpftool prog dump xlated 看汇编 → 对应源码加 bpf_trace_printk 验证分支走向

最常被忽略的一点:eBPF 程序的“执行时间”本身受 verifier 插入的安全检查指令干扰,profile 统计的是包含这些检查的总耗时——你优化的代码可能只占其中一小段,其余全是校验开销。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

866

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

452

2024.06.27

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

616

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

217

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1557

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

642

2023.11.24

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

928

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.5万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号