bpf echo
1.0.0
bpf-echo é um servidor de eco TCP e UDP extremamente rápido que suporta tráfego IPv4 e IPv6. Sua implementação aproveita o Berkeley Packet Filter estendido e o BPF Compiler Collection para redirecionar os pacotes de saída diretamente para a fila de recebimento do soquete de envio. É perfeito para benchmarking de servidores proxy ou bibliotecas de rede, onde você deseja ter certeza de que o servidor upstream não é um gargalo.
Os requisitos para executar bpf-echo
são:
pip3 install pyroute2
python3-bpfcc
nos repositórios de pacotes do Ubuntu. Confira INSTALL.md do bcc para mais detalhes4.1
$ sudo ./bpf-echo --ipv4 127.0.0.1 --port 1122 # run in different terminal
$ echo "hello" | nc -W1 127.0.0.1 1122
hello
usage: bpf-echo.py [-h] [--ipv4 IPV4] [--ipv6 IPV6] [--port PORT]
[--ifname IFNAME]
optional arguments:
-h, --help show this help message and exit
--ipv4 IPV4 IPv4 address that will reflect packets. Disabled if empty
string. (default: 127.0.0.1)
--ipv6 IPV6 IPv6 address that will reflect packets. Disabled if empty
string. (default: )
--port PORT TCP/UDP destination port that will reflect packets.
(default: 12345)
--ifname IFNAME Interface the eBPF classifier will be loaded on. (default:
lo)
A implementação do BPF é bastante simples e, portanto, faz alguns compromissos: