无法卸载 BPF 程序

Unable to unload BPF program

我无法从代码中卸载 BPF 程序。我正在使用 Cilium eBPF library to load the program and netlink 将 BPF 函数添加到接口。这是我正在做的事情:

type BpfObjects struct {
    CollectIpsProg *ebpf.Program        `ebpf:"collect_ips_prog"`
}

    var objects BpfObjects

    // Load the BPF program
    spec, err := ebpf.LoadCollectionSpec("collect_ips.o")

    if err != nil {
        log.Fatalln("ebpf.LoadCollectionSpec", err)
    }

    if err := spec.LoadAndAssign(objects, nil); err != nil {
        log.Fatalln("ebpf.LoadAndAssign", err)
    }

    // Load to XDP
    link, err := netlink.LinkByName("enp0s8")

    if err != nil {
        log.Fatalln("netlink.LinkByName", err)
    }

    err = netlink.LinkSetXdpFdWithFlags(link, objects.CollectIpsProg.FD(), 2)

    if err != nil {
        log.Fatalln("netlink.LinkSetXdpFdWithFlags:", err)
    }
    ...

    // Cleanup. This does not unload the BPF program
    objects.CollectIpsProg.Close()
    objects.CollectIpsProg.Unpin() 

即使我关闭程序,bpftool progxdp-loader status 仍然显示 BPF 程序。我可以使用 bpftoolxdp-loader.

卸载程序

eBPF 程序只有在不再有对它的引用(文件描述符、引脚)时才会卸载,但是网络 links 也有自己的引用。因此,要卸载该程序,您首先必须将其与网络分离 link。

您可以通过将程序 fd 设置为 -1 来实现:

err = netlink.LinkSetXdpFd(link, -1)
if err != nil {
    log.Fatalln("netlink.LinkSetXdpFd:", err)
}