ืฉืืื, ืืืจ! ืืจืฆืื ื ื ืืืืืืข โโืืื ืฉืื ื ืืืื ืื ืกืคืจ ืืืฆืืืชื".
ืืืืืื ืฉืืืืื ื ืืืืจืืืืืืช BPF ืืืฉืืื ืืืชืคืชื ืื ืืฆืืช ืืฉืืืืฉ ืคืขืื ืืคืืขื, ืชืจืืื ื ืขืืืจืื ืืืืจ ืืืชืืจ ืืช ืืืืืืืช ืืขืืงืจืืืช ืฉืื ืืืช ืืฆืื ืื ืืืื.
ืืฉื ืื ืืืืจืื ืืช, ืืื ืชืื ืืช ืืืื ืืงืืช ืืคืื ืคืืคืืืจืืื ืืืชืจ ืืืืชืจ ืืื ืืคืฆืืช ืขื ืืืืืืืช ืฉื ืืืืช ืืื ืืงืก ืืืงืจืื ืืื ื ืืจืฉ ืขืืืื ืื ืืช ืืขื ืืืฆืืขืื ืืืืืื. ืืืช ืืืื ืืงืืช ืืคืืคืืืจืืืช ืืืืชืจ ืืกืื ืื ื ืงืจืืช ืืขืงืฃ ืืืื (ืืขืงืฃ ืืืื) ืืืืคืฉืจ, ืชืื ืขืงืืคืช ืฉืืืช ืจืฉืช ืืงืจื ื, ืืืฆืข ืืช ืื ืขืืืื ืืื ืืช ืืืจืื ืืืฉืชืืฉ. ืขืงืืคืช ืืงืจื ื ืืจืืื ืื ืืฉืืืื ืืืจืืืก ืืจืฉืช ื ืฉืื ืืฉืชืืฉ. ืืืืืื ืืืจืืช, ืืฉืขืืืืื ืขื ืืจืืืก ืจืฉืช, ืื ืื ื ืืกืชืืืื ืขื ืืืจืืืืจ ืฉืื ืืฉืชืืฉ.
ืขื ืืื ืืขืืจืช ืฉืืืื ืืืื ืขื ืืจืืืก ืืจืฉืช ืืชืืื ืืช ืืจืื ืืฉืชืืฉ, ืื ื ืืฆืืฆืืื ืืช ืชืงืืจื ืฉื ืืืืื (ืืืชืื ืืงืฉืจ, ืขืืืื ืฉืืืืช ืจืฉืช, ืคืกืืงืืช ืืื'), ืืื ืื ืืฉืื ืืืฉืจ ืคืืขื ืืืืืจืืืืช ืฉื 10Gb/s ืืืขืื. ืืขืงืฃ ืืืื ืืชืืกืคืช ืฉืืืื ืฉื ืชืืื ืืช ืืืจืืช (ืขืืืื ืืฆืืื) ืืืืื ืื ืืืฆืืขืื ืืืืจ (ืืฉืืื ืืืช NUMA, ืืืืื ืืขืื, ืืื') ืชืืืืื ืืช ืืืกืืืืช ืฉื ืขืืืื ืจืฉืช ืืขื ืืืฆืืขืื ืืืืืื ืืืจืื ืืืฉืชืืฉ. ืืืื ืืืืื ืืืืคืช ืืืืฉื ืืืืฉื ืืื ืืขืืืื ืื ืืช ืืื
ืืืจืืื ืืื ืืจืืงืฆืืืช ืจืฉืช ืืืจืื ืืืฉืชืืฉ ืืฉ ืืกืคืจ ืืกืจืื ืืช:
- ืืืืช ืืขืจืืช ืืืคืขืื ืืื ืฉืืืช ืืคืฉืื ืขืืืจ ืืฉืืื ืืืืจื. ืืืืืื ืฉืชืืื ืืืช ืืจืื ืืฉืชืืฉ ืฆืจืืืืช ืื ืื ืืช ืืืฉืืืื ืฉืืื ืืฉืืจืืช, ืขืืืื ืื ืื ืื ืืช ืืืืืจื ืฉืืื. ืื ืืืืจ ืืขืชืื ืงืจืืืืช ืฉืชืฆืืจื ืืชืื ืช ืื ืืื ืืชืงื ืื ืืฉืื.
- ืืืืืื ืฉืื ื ืืืืชืจืื ืืืืืืื ืขื ืฉืื ืืืืื, ืื ื ืื ืืืืชืจืื ืขื ืื ืคืื ืงืฆืืื ืืืืช ืืจืฉืช ืฉืืกืคืงืช ืืืืื. ืชืืื ืืืช ืืจืื ืืฉืชืืฉ ืืืืืืช ืืืืฉื ืืืืฉ ืชืืื ืืช ืฉืืืื ืืืจ ืืกืืคืงืืช ืขื ืืื ืืืืื ืื ืืขืจืืช ืืืคืขืื.
- ืชืืื ืืืช ืคืืขืืืช ืืืฆื ืืจืื ืืื, ืื ืฉืืืืื ืืืื ืืช ืืืื ืืจืืงืฆืื ืืื ืืื ืืืื ืข ืืื ืืืฉืชืื ืขื ืืืงืื ืืืจืื ืฉื ืืขืจืืช ืืืคืขืื.
ืืขืืงืจื ืฉื ืืืจ, ืืขืช ืืฆืืจืช ืจืฉืชืืช ืืืจืื ืืืฉืชืืฉ, ืจืืืื ืืืฆืืขืื ืืืฉืืื ืขื ืืื ืืขืืจืช ืขืืืื ืื ืืช ืืืงืจื ื ืืืจืื ืืืฉืชืืฉ. XDP ืขืืฉื ืืืืืง ืืช ืืืืคื: ืืื ืืขืืืจ ืชืืื ืืืช ืจืฉืช ืืืจืื ืืืฉืชืืฉ (ืืกื ื ืื, ืจืืืืืจืื, ื ืืชืื ืืื') ืืืจืื ืืงืจื ื. XDP ืืืคืฉืจ ืื ื ืืืฆืข ืคืื ืงืฆืืืช ืจืฉืช ืืจืืข ืฉืืืืื ืคืืืขืช ืืืืฉืง ืจืฉืช ืืืคื ื ืฉืืื ืืชืืืื ืืขืืืช ืืชืื ืชืช-ืืืขืจืืช ืฉื ืจืฉืช ืืงืจื ื. ืืชืืฆืื ืืื, ืืืืจืืช ืขืืืื ืืืืืืืช ืขืืื ืืืืคื ืืฉืืขืืชื. ืขื ืืืช, ืืืฆื ืืืืื ืืืคืฉืจืช ืืืฉืชืืฉ ืืืคืขืื ืืช ืืชืืื ืืืช ืฉืื ืืืื ืืืืื? ืืคื ื ืฉื ืขื ื ืขื ืฉืืื ืื, ืืืื ื ืกืชืื ืขื ืื ืื BPF.
BPF ื-eBPF
ืืืจืืช ืืฉื ืืืืืื, BPF (Berkeley Packet Filtering) ืืื ืืืขืฉื ืืื ืฉื ืืืื ื ืืืจืืืืืืช. ืืืื ื ืืืจืืืืืืช ืื ืชืืื ื ื ืืืงืืจ ืืืคื ืืกืื ืื ืื ืืช, ืืืืื ืืฉื.
ืืื ืืืืื ืืืคืืจืกืืื ืืืืชืจ ืืืืฆืขืืช BPF ืืื tcpdump
. ืืขืช ืืืืืช ืื ืืช ืืืืฆืขืืช tcpdump
ืืืฉืชืืฉ ืืืื ืืฆืืื ืืืืื ืืกืื ืื ืื ืืช. ืจืง ืื ืืช ืืชืืืืืช ืืืืืื ืื ืืืงืืื. ืืืืืื, ืืืืืื "tcp dst port 80
โ ืืชืืืืก ืืื ืื ืืช ื-TCP ืืืืืขืืช ืืืฆืืื 80. ืืืืืจ ืืืื ืืงืฆืจ ืืช ืืืืืื ืืื ืขื ืืื ืืืจืชื ื-BPF bytecode.
$ sudo tcpdump -d "tcp dst port 80"
(000) ldh [12]
(001) jeq #0x86dd jt 2 jf 6
(002) ldb [20]
(003) jeq #0x6 jt 4 jf 15
(004) ldh [56]
(005) jeq #0x50 jt 14 jf 15
(006) jeq #0x800 jt 7 jf 15
(007) ldb [23]
(008) jeq #0x6 jt 9 jf 15
(009) ldh [20]
(010) jset #0x1fff jt 15 jf 11
(011) ldxb 4*([14]&0xf)
(012) ldh [x + 16]
(013) jeq #0x50 jt 14 jf 15
(014) ret #262144
(015) ret #0
ืื ืื ืฉืืชืืื ืืช ืืขืื ืขืืฉื ืืขืฆื:
- ืืืจืื (000): ืืืขื ืืช ืืืืืื ืืืืกื 12, ืืืืื ืฉื 16 ืกืืืืืช, ืืชืื ืืืฆืืจ. ืืืกื 12 ืืชืืื ืืกืื ืืืชืจ ืฉื ืืืืืื.
- ืืืจืื (001): ืืฉืืื ืืช ืืขืจื ืืฆืืืจ ืขื 0x86dd, ืืืืืจ, ืขื ืขืจื ืืืชืจืืืืค ืขืืืจ IPv6. ืื ืืชืืฆืื ื ืืื ื, ืืื ื ืืชืืื ืืช ืขืืืจ ืืืืจืื (002), ืืื ืื, ืื ื- (006).
- ืืืจืื (006): ืืฉืืื ืืช ืืขืจื ื-0x800 (ืขืจื ethertype ืขืืืจ IPv4). ืื ืืชืฉืืื ื ืืื ื, ืื ืืชืืื ืืช ืขืืืจืช ืื (007), ืื ืื, ืื ืื (015).
ืืื ืืืื ืขื ืฉืชืืื ืืช ืกืื ืื ืืื ืืช ืชืืืืจ ืชืืฆืื. ืื ืืืจื ืืื ืืืืืื ืืช. ืืืืจืช ืขืจื ืื ืืคืก (ืืืจืื (014)) ืคืืจืืฉื ืฉืืืืืื ืืชืงืืื, ืืืืืจืช ืขืจื ืืคืก (ืืืจืื (015)) ืคืืจืืฉื ืฉืืืืืื ืื ืืชืงืืื.
ืืืืื ื ืืืืจืืืืืืช BPF ืืงืื ืืืชืื ืฉืื ืืืฆืขื ืขื ืืื ืกืืื ืืงืื ืืื ื'ืืืงืืืกืื ืืกืืฃ 1992 ืืืฉืจ ืืืืจื ืคืืจืกื
ืืืืืื ืฉ-BPF ืืื ืืืื ื ืืืจืืืืืืช, ืืื ืืืืืจื ืืช ืืกืืืื ืฉืื ืชืืื ืืืช ืคืืขืืืช. ืื ืืกืฃ ืืงืื ืืืชืื, ืืื ืื ืืืืืจ ืืช ืืืื ืืืืืจืื ืืืฆืืื (ืืืจืืืช ืืืขืื ื ืืืืฉืืืช ืืืืคื ืืจืืื ืขื ืืืฆืืื), ืืืืจืื (A ื-X; ืืืืจื ืืฆืืจ ืืืื ืืงืก), ืืืกืื ืืืืจืื ืฉืจืืื ืืืื ื ืชืืื ืืืช ืืจืืื. ืืขื ืืื ืืฆืืื ืฉืงืื ืืืืืื ืฉื BPF ืขืืฆื ืขื ืคื ื-Motorola 6502 ISA. ืืคื ืฉืกืืื ืืงืื ื ืืืจ ืืฉืื
ืชืืืืช BPF ืืืืฉืืช ืืืืืช ืืื ืืงืก ืืืจืกืืืช v2.5 ืืืขืื, ืื ืืกืคื ืืขืืงืจ ืขื ืืื ืืืืฆืื ืฉื ื'ืื ืฉืืืืกื. ืงืื BPF ื ืืชืจ ืืื ืฉืื ืื ืขื 2011, ืืืฉืจ ืืจืืง Dumaset ืขืืฆื ืืืืฉ ืืช ืืืชืืจืืื BPF ืื ืฉืืคืขื ืืืฆื JIT (ืืงืืจ:
ืืืืืจ ืืืชืจ, ืืฉื ืช 2014, ืืืืกืื Starovoitov ืืฆืืข ืื ืื ืื JIT ืืืฉ ืขืืืจ BPF. ืืืขืฉื, ื-JIT ืืืืฉ ืืื ืืคื ืืืจืืืืงืืืจื ืืืฉื ืืืืกืกืช BPF ืื ืงืจื eBPF. ืื ื ืืืฉื ืฉืฉื ื ื-VMs ืืชืงืืืื ืืื ืืืฉื ืืื ืื, ืืื ืืจืืข ืกืื ืื ืื ืืช ืืืืฉื ืขื ืืกืืก eBPF. ืืืขืฉื, ืืืืืืืืช ืจืืืช ืฉื ืชืืขืื ืืืืจื ื, BPF ืืืื ื-eBPF, ืื-BPF ืืงืืืกื ืืืืข ืืืื ื-cBPF.
eBPF ืืจืืื ืืช ืืืืื ื ืืืืจืืืืืืช ืืงืืืกืืช BPF ืืืื ืืจืืื:
- ืืืืกืก ืขื ืืจืืืืงืืืจืืช ืืืืจื ืืืช ืฉื 64 ืกืืืืืช. eBPF ืืฉืชืืฉ ืืืืืจืื ืฉื 64 ืกืืืืืช ืืืืืื ืืช ืืกืคืจ ืืืืืจืื ืืืืื ืื ื-2 (ืฆืืจ ื-X) ื-10. eBPF ืืกืคืง ืื ืงืืืื ื ืืกืคืื (BPF_MOV, BPF_JNE, BPF_CALL...).
- ืื ืืชืง ืืชืช ืืืขืจืืช ืฉื ืฉืืืช ืืจืฉืช. BPF ืืื ืงืฉืืจ ืืืืื ื ืชืื ื ืืืฆืืื. ืืืืืื ืฉืืื ืฉืืืฉ ืืกืื ืื ืื ืืช, ืืงืื ืฉืื ืืื ืืืืงื ืืชืช ืืืขืจืืช ืืืกืคืงืช ืชืงืฉืืจืช ืจืฉืช. ืขื ืืืช, ืืืืื ื ืืืืจืืืืืืช eBPF ืืื ื ืงืฉืืจื ืขืื ืืืืื ืื ืชืื ืื ืื ืืชื ืืืฉืชืืฉ ืื ืืื ืืืจื. ืื, ืืขืช ื ืืชื ืืืืจ ืืช ืชืืื ืืช eBPF ืื ืงืืืช ืขืงืืื ืื kprobe. ืื ืคืืชื ืืช ืืืจื ืืืืฉืืจ eBPF, ื ืืชืื ืืืฆืืขืื ืืืงืจื ืฉืืืืฉ ืจืืื ืืืจืื ืืืงืฉืจ ืฉื ืชืช-ืืขืจืืืช ืืืื ืืืจืืช. ืืขืช ืงืื ื-eBPF ืืืืงื ืื ืชืื ืฉืื: kernel/bpf.
- ืืืืจื ื ืชืื ืื ืืืืืืืื ืืฉื ืืคืืช. ืืคืืช ืื ืืืืจื ืืคืชื-ืขืจื ืืืืคืฉืจืื ืืืืืคื ื ืชืื ืื ืืื ืืจืื ืืืฉืชืืฉ ืืืจืื ืืงืจื ื. eBPF ืืกืคืง ืืกืคืจ ืกืืืื ืฉื ืืคืืช.
- ืคืื ืงืฆืืืช ืืฉื ืืืช. ืืคืจื, ืืื ืืฉืืชื ืืืืื, ืืืฉื ืกืืื ืืืงืืจืช ืื ืืฉืืคื ืืืืื. ืคืื ืงืฆืืืช ืืื ืคืืขืืืช ืืชืื ืืืืื ืืืื ื ืชืืื ืืืช ืืจืื ืืฉืชืืฉ. ืืชื ืืืื ืื ืืืฆืข ืฉืืืืช ืืขืจืืช ืืชืืื ืืืช eBPF.
- ืกืืื ืฉืืืืช. ืืืื ืืชืืื ืืช ื-eBPF ืืืืื ื-4096 ืืชืื. ืชืืื ืช ื-tail call ืืืคืฉืจืช ืืชืืื ืืช eBPF ืืืขืืืจ ืืช ืืฉืืืื ืืชืืื ืืช eBPF ืืืฉื ืืืื ืืขืงืืฃ ืืืืื ืื (ื ืืชื ืืงืฉืจ ืขื 32 ืชืืื ืืืช ืืืจื ืื).
eBPF: ืืืืื
ืืฉื ื ืืกืคืจ ืืืืืืืช ืขืืืจ eBPF ืืืงืืจืืช ืืืืช ืืื ืืงืก. ืื ืืืื ืื ื- samples/bpf/. ืืื ืืืจืืื ืืช ืืืืืืืืช ืืืื, ืคืฉืื ืืื:
$ sudo make samples/bpf/
ืื ื ืื ืืืชืื ืืืืื ืืืฉื ืขืืืจ eBPF ืืขืฆืื, ืืื ืืฉืชืืฉ ืืืืช ืืืืืืืืช ืืืืื ืืช ื- samples/bpf/. ืื ื ืืกืชืื ืขื ืืืงืื ืืกืืืืื ืฉื ืืงืื ืืืกืืืจ ืืื ืืื ืขืืื. ืืืืืื, ืืืจืชื ืืชืืื ืืช tracex4
.
ืืืืคื ืืืื, ืื ืืืช ืืืืืืืืืช ืืืืืืืืช/bpf/ ืืืจืืืช ืืฉื ื ืงืืฆืื. ืืืงืจื ืืื:
tracex4_kern.c
, ืืืื ืืช ืงืื ืืืงืืจ ืฉืืืืฆืข ืืืืื ืืชืืจ eBPF bytecode.tracex4_user.c
, ืืืื ืชืืื ืืช ืืืจืื ืืืฉืชืืฉ.
ืืืงืจื ืื, ืขืืื ื ืืืฆืข ืงืืืคืืืฆืื tracex4_kern.c
ืืงืื ืืชืื eBPF. ืืจืืข ื gcc
ืืื ืงืฆื ืืืืจื ืขืืืจ eBPF. ืึฐืึทืจึฐืึผึถื ืึทืึทืึธื, clang
ืืืื ืืืืฆืื eBPF bytecode.
ะธัะฟะพะปัะทัะตั clang
ืืืืืืจ tracex4_kern.c
ืืงืืืฅ ืืืืืืืงื.
ืฆืืื ืชื ืืืขืื ืฉืืืช ืืชืืื ืืช ืืืขื ืืื ืืช ืืืืชืจ ืฉื eBPF ืื ืืคืืช. tracex4_kern ืืืืืจ ืืคื ืืืช:
struct pair {
u64 val;
u64 ip;
};
struct bpf_map_def SEC("maps") my_map = {
.type = BPF_MAP_TYPE_HASH,
.key_size = sizeof(long),
.value_size = sizeof(struct pair),
.max_entries = 1000000,
};
BPF_MAP_TYPE_HASH
ืืื ืืื ืืกืืื ืืืจืืืกืื ืืจืืื ืืืืฆืขืื ืขื ืืื eBPF. ืืืงืจื ืืื, ืื ืจืง ืืฉืืฉ. ืืืชืื ืฉืื ืฉืืช ืื ืืืืืขื SEC("maps")
. SEC ืืื ืืืงืจื ืืืฉืืฉ ืืืฆืืจืช ืงืืข ืืืฉ ืฉื ืงืืืฅ ืืื ืืจื. ืืขืฆื, ืืืืืื tracex4_kern
ืฉื ื ืกืขืืคืื ื ืืกืคืื ืืืืืจืื:
SEC("kprobe/kmem_cache_free")
int bpf_prog1(struct pt_regs *ctx)
{
long ptr = PT_REGS_PARM2(ctx);
bpf_map_delete_elem(&my_map, &ptr);
return 0;
}
SEC("kretprobe/kmem_cache_alloc_node")
int bpf_prog2(struct pt_regs *ctx)
{
long ptr = PT_REGS_RC(ctx);
long ip = 0;
// ะฟะพะปััะฐะตะผ ip-ะฐะดัะตั ะฒัะทัะฒะฐััะตะน ััะพัะพะฝั kmem_cache_alloc_node()
BPF_KRETPROBE_READ_RET_IP(ip, ctx);
struct pair v = {
.val = bpf_ktime_get_ns(),
.ip = ip,
};
bpf_map_update_elem(&my_map, &ptr, &v, BPF_ANY);
return 0;
}
ืฉืชื ืืคืื ืงืฆืืืช ืืืื ืืืคืฉืจืืช ืื ืืืืืง ืขืจื ืืืืคื (kprobe/kmem_cache_free
) ืืืืกืืคื ืขืจื ืืืฉ ืืืคื (kretprobe/kmem_cache_alloc_node
). ืื ืฉืืืช ืืคืื ืงืฆืืืช ืฉื ืืชืื ืืืืชืืืช ืืืืืืช ืชืืืืื ืืคืงืืืืช ืืืงืจื ืฉืืืืืจื ื
.
ืื ืื ื ืืืจืง ืืช ืืงืืขืื ืฉื ืงืืืฅ ืืืืืืืงื, ืื ื ืืืืจ ืืจืืืช ืฉืืงืืขืื ืืืืฉืื ืืืื ืืืจ ืืืืืจืื:
$ objdump -h tracex4_kern.o
tracex4_kern.o: file format elf64-little
Sections:
Idx Name Size VMA LMA File off Algn
0 .text 00000000 0000000000000000 0000000000000000 00000040 2**2
CONTENTS, ALLOC, LOAD, READONLY, CODE
1 kprobe/kmem_cache_free 00000048 0000000000000000 0000000000000000 00000040 2**3
CONTENTS, ALLOC, LOAD, RELOC, READONLY, CODE
2 kretprobe/kmem_cache_alloc_node 000000c0 0000000000000000 0000000000000000 00000088 2**3
CONTENTS, ALLOC, LOAD, RELOC, READONLY, CODE
3 maps 0000001c 0000000000000000 0000000000000000 00000148 2**2
CONTENTS, ALLOC, LOAD, DATA
4 license 00000004 0000000000000000 0000000000000000 00000164 2**0
CONTENTS, ALLOC, LOAD, DATA
5 version 00000004 0000000000000000 0000000000000000 00000168 2**2
CONTENTS, ALLOC, LOAD, DATA
6 .eh_frame 00000050 0000000000000000 0000000000000000 00000170 2**3
CONTENTS, ALLOC, LOAD, RELOC, READONLY, DATA
ืืฉ ืื
, ืชืืื ื ืจืืฉืืช. ืืขืืงืจืื, ืืชืืื ืืช ืืื ืืืืื ื ืืืืจืืขืื kmem_cache_alloc_node
. ืืืฉืจ ืืืจืืข ืืื ืืชืจืืฉ, ืงืื ื-eBPF ืืืชืืื ืืืืฆืข. ืืงืื ืฉืืืจ ืืช ืชืืื ืช ื-IP ืฉื ืืืืืืืงื ืืืคื, ืืื ืืืืืืืงื ืขืืืจ ืืืืืื ืืจื ืืชืืื ืืช ืืจืืฉืืช. ืืืืื:
$ sudo ./tracex4
obj 0xffff8d6430f60a00 is 2sec old was allocated at ip ffffffff9891ad90
obj 0xffff8d6062ca5e00 is 23sec old was allocated at ip ffffffff98090e8f
obj 0xffff8d5f80161780 is 6sec old was allocated at ip ffffffff98090e8f
ืืื ืชืืื ืืช ืืจืื ืืฉืชืืฉ ืืชืืื ืืช eBPF ืงืฉืืจืืช? ืขื ืืชืืื tracex4_user.c
ืืืขื ืงืืืฅ ืืืืืืงื tracex4_kern.o
ืืืืฆืขืืช ืืคืื ืงืฆืื load_bpf_file
.
int main(int ac, char **argv)
{
struct rlimit r = {RLIM_INFINITY, RLIM_INFINITY};
char filename[256];
int i;
snprintf(filename, sizeof(filename), "%s_kern.o", argv[0]);
if (setrlimit(RLIMIT_MEMLOCK, &r)) {
perror("setrlimit(RLIMIT_MEMLOCK, RLIM_INFINITY)");
return 1;
}
if (load_bpf_file(filename)) {
printf("%s", bpf_log_buf);
return 1;
}
for (i = 0; ; i++) {
print_old_objects(map_fd[1]);
sleep(1);
}
return 0;
}
ืืขืช ืืืฆืืข
ืืืืงืืช ืืืืืืจืืช ืืงืืืฅ eBPF ืืชืืืกืคืืช /sys/kernel/debug/tracing/kprobe_events
. ืขืืฉืื ืื ืื ื ืืงืฉืืืื ืืืืจืืขืื ืืืื ืืืชืืื ืืช ืฉืื ื ืืืืื ืืขืฉืืช ืืฉืื ืืฉืื ืืชืจืืฉืื.
$ sudo cat /sys/kernel/debug/tracing/kprobe_events
p:kprobes/kmem_cache_free kmem_cache_free
r:kprobes/kmem_cache_alloc_node kmem_cache_alloc_node
ืื ืฉืืจ ืืชืืื ืืืช ื-example/bpf/ ืื ืืืืช ืืืืคื ืืืื. ืื ืชืืื ืืืืืื ืฉื ื ืงืืฆืื:
XXX_kern.c
: ืชืืื ืืช eBPF.XXX_user.c
: ืชืืื ื ืจืืฉืืช.
ืชืืื ืืช eBPF ืืืื ืืคืืช ืืคืื ืงืฆืืืช ืืงืฉืืจืืช ืืืงืืข. ืืืฉืจ ืืงืจื ื ืื ืคืืง ืืืจืืข ืืกืื ืืกืืื (ืืืืืื, tracepoint
), ืืคืื ืงืฆืืืช ืืืืืืืืช ืืืืฆืขืืช. ืืืจืืืกืื ืืกืคืงืื ืชืงืฉืืจืช ืืื ืชืืื ืืช ืืงืจื ื ืืชืืื ืืช ืืจืื ืืืฉืชืืฉ.
ืืกืงื ื
ืืืืจ ืื ืื ื-BPF ืื-eBPF ืืืื ืืื ืืืืืื. ืื ื ืืืืข ืฉืืฉ ืืจืื ืืืืข ืืืฉืืืื ืขื eBPF ืืืื, ืื ืื ื ืืืืืฅ ืขื ืืื ืืฉืืืื ื ืืกืคืื ืืืืงืจ ื ืืกืฃ
ืื ื ืืืืืฅ ืืงืจืื:
BPF: ืืืืื ื ืืืืจืืืืืืช ืืืื ืืืจืกืืืช ืืชืื ืืืืื ื'ืื ืชื ืงืืจืื. ืืืื ื-BPF ืืืืฆื ืืื ืืชืคืชื ื-eBPF.ืืืืจืืช ืืกืืืืช ืขื eBPF ืืจื ืื ืืจื. ืืืืจ ื-LWN.net. ืืจื ืื ืืจืื ืืฆืืืฅ ืขื eBPF ืืื ืื ืจืฉืืื ืฉื ืืฉืืืื ืื ืืฉื ืฉืืืคืืกื ืืืืื .ืืขืจืืช ืขื BPF ื-eBPF ื'ืืืื ืืืื ืก. ืืขืจืืช ืขื ืืืฆืืช ืฉื Suchakra Sharma "ืืกื ื ืื ืืช BSD: ืืจืืืืงืืืจื ืืืฉื ืืืืืืช ืื ืืช ืืจืืช ืืืฉืชืืฉ". ืืืขืจืืช ืืืืืช ืืืืืช ืขืืืจืืช ืื ืืืืื ืืช ืืฉืงืืคืืืช.eBPF, ืืืง 1: ืขืืจ, ืืืื ืืขืชืื ืคืจืืก ืืืืก. Longread ืขืืึถืึฐืฉืึตื , ืืื ืืืื ืืงืจืื. ืืื ืืืืืจืื ืืืืืื ืืืืชืจ ืฉื ืชืงืืชื ืืื ื-eBPF.
ืืงืืจ: www.habr.com