Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/martichou/nrt-onl
Near Real Time Outage Notification Library
https://github.com/martichou/nrt-onl
ebpf
Last synced: 16 days ago
JSON representation
Near Real Time Outage Notification Library
- Host: GitHub
- URL: https://github.com/martichou/nrt-onl
- Owner: Martichou
- Created: 2024-01-14T18:45:01.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2024-10-08T21:00:10.000Z (4 months ago)
- Last Synced: 2025-01-07T03:14:17.731Z (19 days ago)
- Topics: ebpf
- Language: Rust
- Homepage:
- Size: 93.8 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# n-rt-onl
**TLDR**: Operating system support:
| Operating System | userspace | ebpf |
|---|---|---|
| Windows | yes | no |
| macOS | yes | no |
| Linux | yes | yes |Features:
- default: eBPF on Linux and userspace on macOS/Windows
- userspace: userspace on all OSes# Linux (default - ebpf, userspace available)
The Linux version use eBPF with TC in order to perform the analysis on the TX/RX packets.
### Prerequisites
1. Install bpf-linker: `cargo install bpf-linker`
### Build eBPF
```bash
cargo xtask build-ebpf
```To perform a release build you can use the `--release` flag.
You may also change the target architecture with the `--target` flag.### Build Userspace
```bash
cargo build
```### Run
```bash
export RUST_LOG=info
cargo xtask run
```### Use the library
You can check the [example](examples/nrt_test/). You'll need to download the ebpf program
and place it somewhere accessible for the user running the binary.# macOS and Windows (only userspace)
The macOS and Windows version use pnet's datalink::channel.
### Prerequisites
1. None, just Rust
### Run
```bash
export RUST_LOG=info
cargo run
```### Use the library
Same as for the Linux (they share the same API), but you don't need to
specify the eBPF program path.