#sockets #libbpf #traffic #monitor #networking #host #filter

socket_filter

A simple bpf program to monitor host's net traffic

10 releases

0.2.2 Oct 23, 2024
0.2.1 Oct 15, 2024
0.1.10 Oct 2, 2024
0.1.4 Sep 27, 2024

#4 in #socket

Download history 358/week @ 2024-09-26 95/week @ 2024-10-03 295/week @ 2024-10-10 202/week @ 2024-10-17 91/week @ 2024-10-24 3/week @ 2024-10-31 28/week @ 2024-11-28 70/week @ 2024-12-05 28/week @ 2024-12-12 7/week @ 2024-12-19 1/week @ 2024-12-26

114 downloads per month

LGPL-2.1-only OR BSD-2-Clause

605KB
177 lines

use epbf program type BPF_PROG_TYPE_SOCKET_FILTER to monitor the network traffic of the host.

Example

use std::mem::MaybeUninit;

pub fn main() -> Result<(), Box<dyn std::error::Error>> {
    let mut open_object = MaybeUninit::uninit(); // make the ebpf prog lives as long as the process.
    let socket_filter =
        socket_filter::TransmitCounter::new(&mut open_object, socket_filter::IGNORED_IFACE)?;
    loop {
        println!(
            "current bytes: {} {}",
            socket_filter.get_egress(),
            socket_filter.get_ingress()
        );
        std::thread::sleep(std::time::Duration::from_secs(1));
    }
}


lib.rs:

socket_filter

socket_filter is a library to monitor the network traffic of a network interface. By passing a list of interface names to this library, it will attach to the interfaces and monitor the network traffic of the interfaces.

Dependencies

~15MB
~313K SLoC