bpftune

bpftune 项目介绍

项目定位

bpftune 是一个基于 BPF 的 Linux 系统自动调优工具,旨在通过 BPF 技术提供轻量级、持续运行的系统行为自动优化能力。其核心定位包括:

  1. 解决系统调优复杂性问题:Linux 内核包含大量可调节参数(如 sysctl 参数),在 6.2 内核中已超过 1600 个,手动调优难度极大。

  2. 适应现代系统管理模式:针对 "牛群而非宠物" 的云架构理念,满足系统自动运维需求,减少人工干预。

  3. 动态自适应调优:利用 BPF 的低开销可观测性,持续监控系统行为并实时调整,同时能观察调优效果并进行再优化。

  4. 细粒度调优能力:相比传统的系统级粗粒度统计,可实现针对单个套接字、设备等的细粒度调优。

使用方式

环境要求

  • 内核需支持 BPF 环形缓冲区(约 5.6 内核及以上,Oracle Linux 5.4 版本因反向移植也支持)

  • 启用内核 BTF(CONFIG_DEBUG_INFO_BTF=y),需存在 /sys/kernel/btf/vmlinux 文件

  • 依赖软件包(名称可能因发行版而异):

    • libbpf、libbpf-devel ≥ 0.6

    • libcap-devel

    • bpftool ≥ 4.18

    • libnl3-devel(部分发行版需 libnl-route-3-dev)

    • clang ≥ 11、llvm ≥ 11

    • python3-docutils

安装步骤

  1. 手动编译安装
go 复制代码
\$ make

\$ sudo make install
  1. 构建 RPM 包
ruby 复制代码
\$ make pkg  # 生成 RPM 包,详见 buildrpm/bpftune.spec
  1. 非标准 libdir 安装(如 CachyOS):
ini 复制代码
\$ make libdir=lib

\$ sudo make install libdir=lib
  1. 使用 GCC BPF 支持编译
ini 复制代码
\$ GCC\_BPF=bpf-unknown-none-gcc make

服务管理

  1. 启动服务
ruby 复制代码
\$ sudo service bpftune start
  1. 设置开机自启
bash 复制代码
\$ sudo systemctl enable bpftune
  1. 前台运行(输出到标准输出 / 错误)
ruby 复制代码
\$ sudo bpftune -s

主要功能使用

  1. 查询状态
ruby 复制代码
\$ bpftune -q  # 查询 bpftune 状态
  1. 检查系统支持性
ruby 复制代码
\$ bpftune -S  # 检查系统是否支持 bpftune 所需的 BPF 特性
  1. 指定学习率(0-4,数值越高调整幅度越大):
ruby 复制代码
\$ bpftune -r \<learning\_rate>
  1. 回滚操作
ruby 复制代码
\$ bpftune -R  # 启用回滚功能

日志与监控

  • 日志默认记录在 syslog 中,可通过 /var/log/messages 查看调优详情

  • 支持通过 Performance Co-Pilot (PCP) 导出调优指标,可集成 Grafana 进行可视化监控

测试

  • 测试位于 tests/ 子目录,使用网络命名空间模拟与远程主机的交互

  • 运行所有测试:

bash 复制代码
\$ make test

核心特性

  • 支持动态加载调优器(以共享对象形式)

  • 网络命名空间感知,可对容器进行自动调优

  • 包含多种调优器(如 UDP 缓冲区调优器、netns 调优器等)

  • 通过 inotify 监控调优器目录,支持动态添加 / 移除调优器

  • 可配置的学习率,平衡调优幅度和频率

参考资源

相关推荐
有来技术2 小时前
ASP.NET Core 权限管理系统(RBAC)设计与实现|vue3-element-admin .NET 后端
vue.js·后端·c#·asp.net·.net
qq_12498707532 小时前
基于springboot的林业资源管理系统设计与实现(源码+论文+部署+安装)
java·vue.js·spring boot·后端·spring·毕业设计·计算机毕业设计
shuair2 小时前
springboot整合redisson单机模式
java·spring boot·后端
qq_12498707532 小时前
基于springboot的竞赛团队组建与管理系统的设计与实现(源码+论文+部署+安装)
java·vue.js·spring boot·后端·信息可视化·毕业设计·计算机毕业设计
Dr.Kun3 小时前
【鲲码园PsychoPy】Go/No-go范式
开发语言·后端·golang
源代码•宸3 小时前
Redis 攻略(Redis Object)
数据库·redis·后端·缓存·字符串·哈希表·type
林shir3 小时前
3-14-后端Web进阶(SpringBoot原理)
java·spring boot·后端
90的程序爱好者3 小时前
flask入门
后端·python·flask
源代码•宸3 小时前
Golang面试题库(Interface、GMP)
开发语言·经验分享·后端·面试·golang·gmp·调度过程
西京刀客3 小时前
Go 语言中的 toolchain 指令-toolchain go1.23.6的作用和目的
开发语言·后端·golang·toolchain