
Nsave 是一个抓取并保存数据包的工具。它持续不断地抓取数据包,并保存到本地。可以根据条件查询链接、数据包并导出成pcap文件。可以通过pcap 或者af_xdp来捕获数据包。主要特点是它不基于单个数据包,而是基于流来作索引,可以大幅减少索引所占的磁盘空间。
Linux
cp nsave\_conf.toml ~/.nsave\_conf.tomlrustup toolchain install stablerustup toolchain install nightly --component rust-srccargo install bpf-linker(在 macOS 上使用 --no-default-features)正常使用 cargo build、cargo check 等命令。运行程序使用:
RUST\_LOG=info cargo run --bin nsave --config 'target."cfg(all())".runner="sudo -E"' -- --iface ens192
cargo run --release --bin nsave --config 'target."cfg(all())".runner="sudo -E"' -- --iface ens192Cargo 构建脚本会自动正确构建 eBPF 并将其包含在程序中。
可以根据时间,五元祖,bfp过滤器来查询链接或数据包。
查询五元祖的链接:
nsave-cli search -s 2024-03-28-12:00:00 -e 2024-03-28-22:00:00 --sip 111.206.208.245 -D 10.11.20.13 -P tcp -p 443 -d 64024将查询结果dump成pcap文件:
nsave-cli search -s 2024-05-18-15:36:36 -e 2024-05-18-15:36:47 --sip 10.11.20.255 -D 10.11.20.14 -P udp -p 137 -d 137 -f ~/misc/nsave\_data/dump.pcap以bpf过滤器来查询数据包:
nsave-cli bpf\_search -s 2024-07-28-21:10:00 -e 2024-07-28-21:15:00 --bpf “udp and arp”bpf查询也可以dump成pcap文件:
nsave-cli -c nsave\_conf.toml bpf\_search -s 2024-07-28-21:10:00 -e 2024-07-28-21:15:00 --bpf "tcp or udp" -f ~/misc/nsave\_data/dump.pcap原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。