0

0

bpftrace 运行报 "failed to attach to tracepoint" 的权限与内核 CONFIG

冷漠man

冷漠man

发布时间:2026-02-04 23:32:03

|

488人浏览过

|

来源于php中文网

原创

bpftrace 报 failed to attach to tracepoint 错误的根本原因只有两个:用户无 cap_sys_admin 权限(sudo 不一定足够),或内核未启用 CONFIG_TRACEPOINTS=y、CONFIG_BPF_SYSCALL=y、CONFIG_BPF_JIT=y(或 CONFIG_BPF_INTERPRETER=y)三者之一。

bpftrace 运行报 \

为什么 bpftrace 报 failed to attach to tracepoint

这个错误不是 bpftrace 本身的问题,而是内核拒绝了 tracepoint 的 attach 请求。根本原因通常只有两个:当前用户没有足够权限,或者内核编译时没开启对应配置项。

普通用户默认无法 attach 到 tracepoint(哪怕只是读取),因为这属于内核调试接口,需要 cap_sys_admin 或 root 权限;而即使你用了 sudo,如果内核没打开关键选项,依然会失败——此时错误信息完全一样,容易误判。

必须检查的内核 CONFIG 选项

bpftrace 依赖 tracepoint 的 BPF 程序挂载能力,以下三个内核配置项缺一不可:
  • CONFIG_TRACEPOINTS=y —— tracepoint 基础框架,几乎所有发行版都已启用
  • CONFIG_BPF_SYSCALL=y —— BPF 系统调用入口,bpftrace 的底层支撑
  • CONFIG_BPF_JIT=y(推荐)或 CONFIG_BPF_INTERPRETER=y —— JIT 编译器或解释器,决定 BPF 程序能否执行

最容易被忽略的是 CONFIG_BPF_JIT:某些嵌入式或最小化内核(如部分 Alpine Linux、Debian netinst 镜像)可能只开了 CONFIG_BPF_SYSCALL,但没开 JIT 或 interpreter,导致 attach 时静默失败并报错 failed to attach to tracepoint

验证方式:

zcat /proc/config.gz | grep -E "(TRACEPOINTS|BPF_SYSCALL|BPF_JIT|BPF_INTERPRETER)"
或查看 /boot/config-$(uname -r)

权限问题:sudo 不一定够,cap_sys_admin 才是关键

即使加了 sudo,如果系统启用了严格的安全模块(如某些 SELinux 策略、或 systemd 的 RestrictSUIDSGID=yes),仍可能丢掉 cap_sys_admin。常见现象:

  • 在容器里运行 bpftrace(未加 --privileged--cap-add=SYS_ADMIN
  • 使用 sudo -u someuser 切换用户后执行,cap 被丢弃
  • systemd service 中未显式设置 CapabilityBoundingSet=CAP_SYS_ADMIN

快速验证是否是权限问题:

sudo capsh --print | grep sys_admin
。如果没有输出,说明当前 shell 没有该 capability。

MakeSong
MakeSong

AI音乐生成,生成高质量音乐,仅需30秒的时间

下载

tracepoint 名称拼写与可用性检查

bpftrace 不会自动提示 tracepoint 是否真实存在。拼错名称(比如把 syscalls:sys_enter_openat 写成 syscalls:sys_enter_open)或目标 tracepoint 在当前内核中尚未导出,也会触发相同错误。

查可用 tracepoint 列表:

sudo cat /sys/kernel/debug/tracing/events/syscalls/
(需先挂载 debugfs)。注意路径中的子目录名即 tracepoint category,文件名即 event name。

更稳妥的方式是用 bpftrace 自带的发现机制:

sudo bpftrace -l 'tracepoint:syscalls:*'
。如果这条命令也报错,基本可锁定为内核配置或权限问题。

真正麻烦的往往是内核配置和 capability 的组合问题:你 sudo 了,cap_sys_admin 也在,但 CONFIG_BPF_INTERPRETERn,这时候错误信息不会告诉你缺了解释器——它只会说 attach 失败。

相关文章

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

833

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

330

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

351

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1386

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

365

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

963

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

427

2024.04.29

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

61

2026.02.04

热门下载

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

精品课程

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

共48课时 | 8.5万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

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

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