From d824192740a871e9c3738c9fd1c4a9057b904fed Mon Sep 17 00:00:00 2001 From: krisztianfekete <103492698+krisztianfekete@users.noreply.github.com> Date: Fri, 9 Dec 2022 16:22:06 +0100 Subject: [PATCH] Fix the target pid of oomkill example, expose metrics by default (#91) --- examples/oomkill/README.md | 6 ++++-- examples/oomkill/oomkill.c | 6 +++--- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/examples/oomkill/README.md b/examples/oomkill/README.md index 8fc0a02..e4776f0 100644 --- a/examples/oomkill/README.md +++ b/examples/oomkill/README.md @@ -40,7 +40,7 @@ bee run -f="exits,tcomm,bash" ghcr.io/solo-io/bumblebee/oomkill:$(bee version) Visualizing and alerting on oomkills is crucial, and Bumblebee can help you with that. -You can modify your `oomkills` structure to generate a `counter` from the oomkill events: +Since we have the `.counter` prefix added to our `oomkills` map, exposing the oomkill events as a `counter` metric is enabled by default: ```c struct { @@ -48,4 +48,6 @@ struct { __uint(max_entries, 1 << 24); __type(value, struct data_t); } oomkills SEC(".maps.counter"); -``` \ No newline at end of file +``` + +To disable this functionality, you can change the suffix to `.print`. diff --git a/examples/oomkill/oomkill.c b/examples/oomkill/oomkill.c index fda2fd9..8453c82 100644 --- a/examples/oomkill/oomkill.c +++ b/examples/oomkill/oomkill.c @@ -20,7 +20,7 @@ struct { __uint(type, BPF_MAP_TYPE_RINGBUF); __uint(max_entries, 1 << 24); __type(value, struct data_t); -} oomkills SEC(".maps.print"); +} oomkills SEC(".maps.counter"); SEC("kprobe/oom_kill_process") int BPF_KPROBE(oom_kill_process, struct oom_control *oc, const char *message) @@ -32,7 +32,7 @@ int BPF_KPROBE(oom_kill_process, struct oom_control *oc, const char *message) return 0; } - e->tpid = bpf_get_current_pid_tgid(); + e->tpid = BPF_CORE_READ(oc, chosen, tgid); bpf_get_current_comm(&e->fcomm, TASK_COMM_LEN); e->fpid = bpf_get_current_pid_tgid() >> 32; @@ -44,4 +44,4 @@ int BPF_KPROBE(oom_kill_process, struct oom_control *oc, const char *message) return 0; } -char LICENSE[] SEC("license") = "GPL"; \ No newline at end of file +char LICENSE[] SEC("license") = "GPL";