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 监控调优器目录,支持动态添加 / 移除调优器

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

参考资源

相关推荐
你的人类朋友1 天前
设计模式有哪几类?
前端·后端·设计模式
Yeats_Liao1 天前
Go Web 编程快速入门 10 - 数据库集成与ORM:连接池、查询优化与事务管理
前端·数据库·后端·golang
你的人类朋友1 天前
适配器模式:适配就完事了bro!
前端·后端·设计模式
间彧1 天前
SpringBoot集成RocketMQ事务消息
后端
间彧1 天前
RocketMQ消息幂等控制:借助数据库唯一约束实现
后端
间彧1 天前
RocketMQ消息幂等控制:借助Redis实现
后端
霸道流氓气质1 天前
SpringBoot+MybatisPlus+自定义注解+切面实现水平数据隔离功能(附代码下载)
java·spring boot·后端
间彧1 天前
RocketMQ消息幂等控制:借助ConcurrentHashMap的putIfAbsent方法实现
后端
why技术1 天前
1K+Star的开源项目能给一个在校大学生带来什么?
前端·人工智能·后端