gobpf

Go bindings for creating BPF programs.

  • Owner: iovisor/gobpf
  • Platform:
  • License:: Apache License 2.0
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

gobpf

Build Status GoDoc

This repository provides go bindings for the bcc framework
as well as low-level routines to load and use eBPF programs from .elf
files.

gobpf is at an early stage but is usable nonetheless. Input and contributions
are very welcome.

We recommend vendoring gobpf and pinning its version as the API is likely to
change during development.

Requirements

eBPF requires a recent Linux kernel. A good feature list can be found here:
https://github.com/iovisor/bcc/blob/master/docs/kernel-versions.md

github.com/iovisor/gobpf/bcc

Install the latest released version of libbcc
(either using a package manager or by building from source).

github.com/iovisor/gobpf/elf

Building ELF Object Files

To build ELF object files for use with the elf package, you must use specific
sections (SEC("...")). The following are currently supported:

  • kprobe/...
  • cgroup/skb
  • cgroup/sock
  • maps/...
  • socket...
  • tracepoint...
  • uprobe/...
  • uretprobe/...
  • xdp/...

Map definitions must correspond to bpf_map_def from the elf package.
Otherwise, you will encounter an error like only one map with size 280 bytes allowed per section (check bpf_map_def).

The Cilium BPF docs contain helpful info
for using clang/LLVM to compile programs into elf object files:
https://cilium.readthedocs.io/en/latest/bpf/#llvm

See tests/dummy.c for a minimal dummy and https://github.com/weaveworks/tcptracer-bpf
for a real world example.

Examples

Sample code can be found in the examples/ directory. Examples can be run as
follows:

sudo -E go run examples/bcc/perf/perf.go

Tests

The semaphore.sh script can be used to run the tests in rkt stage1-kvm
containers on different kernel versions. To run all tests on the host system,
use go test as follows:

go test -tags integration -v ./...

Main metrics

Overview
Name With Owneriovisor/gobpf
Primary LanguageC
Program languageGo (Language Count: 3)
Platform
License:Apache License 2.0
所有者活动
Created At2016-11-18 18:27:13
Pushed At2023-08-31 05:47:21
Last Commit At2022-10-05 08:38:22
Release Count3
Last Release Namev0.2.0 (Posted on 2021-05-06 09:38:03)
First Release Namev0.1.0 (Posted on 2021-03-05 10:56:08)
用户参与
Stargazers Count2.2k
Watchers Count55
Fork Count312
Commits Count408
Has Issues Enabled
Issues Count113
Issue Open Count56
Pull Requests Count154
Pull Requests Open Count29
Pull Requests Close Count37
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private