Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/knrt10/proxify
Simple raw TCP proxy with eBPF support
https://github.com/knrt10/proxify
ebpf golang
Last synced: 3 months ago
JSON representation
Simple raw TCP proxy with eBPF support
- Host: GitHub
- URL: https://github.com/knrt10/proxify
- Owner: knrt10
- License: apache-2.0
- Created: 2022-06-04T00:21:45.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-06-04T01:42:02.000Z (over 2 years ago)
- Last Synced: 2024-11-02T07:10:16.235Z (3 months ago)
- Topics: ebpf, golang
- Language: Go
- Homepage:
- Size: 20.5 KB
- Stars: 27
- Watchers: 2
- Forks: 5
- Open Issues: 2
-
Metadata Files:
- Readme: readme.md
- License: license
Awesome Lists containing this project
README
> Proxy your raw TCP requests
# Contents
- [Demo](#demo)
- [Features](#features)
- [Prerequisites](#prerequisites)
- [Usage](#usage)
- [Running the code](#running-the-code)
- [Internals](#internals)
- [eBPF](#ebpf)
- [Testing](#testing)
- [TODO](#todo)
- [Inspiration](#inspiration)## Demo
[![Demo](https://asciinema.org/a/499416.svg)](https://asciinema.org/a/499416?autoplay=1)## Features
- `proxify` is a simple tool, which routes connection on specific port to given targets.
- It supports `eBPF steering` which routes connections on any configured port to proxifies's listener port.## Prerequisites
You'll need a Linux host running kernel >= 5.9 (when they introduced sk_lookup) to build and run your BPF program. Linux in Docker on an M1 Mac will _not_ work. If you don't have access to a Linux box and can't run a VM you can spin up a dev VM.
You'll need the following tools and libraries installed:
- `bpftool` compiled for a >= 5.9 kernel, because pre-5.9 `bpftool` doesn't know what an sk_lookup program is.
- `libbpf` source code, which you can get from Github, because it has a recent `bpf_helper_defs.h` with `bpf_sk_assign` in it, which you need to make this program work.
- clang>10 to generate ELF .o's that new bpftool will load from.- [go-bindata](https://github.com/go-bindata/go-bindata/): Install using `go install -a -v github.com/go-bindata/go-bindata/...@latest`
## Usage
```
➜ ./proxify --help
Usage of ./proxify:
-b enable bpf steering
-p int
listener port for bpf steering (default 8080)
```## Running the code
```bash
# Build the proxify binary
make proxify# To run in normal mode. Open up terminal and run the following command
./proxify# To run in eBPF steering mode. Open up terminal and run the following.
sudo ./proxify -b# On a different termial, run the following command
echo "hello there general kenobi" | nc -N -4 localhost 5001
```## Internals
See [docs/architecture](docs/architecture.md)
## eBPF
### Testing
```bash
# Run in eBPF steering mode. Open up terminal and run the following.
sudo ./proxify -b# On a different termial, run the following command
echo "hello there general kenobi" | nc -N -4 localhost 5001# Check bpfmaps
sudo bpftool map# Dump map data from id
sudo bptfool map dump id# Update new data to proxy_ports map. This adds port 7 to it.
sudo bpftool map update id key 0x07 0x00 value 0x00# Test the connection, it should work
echo "hello there general kenobi" | nc -N -4 localhost 7# Check link
sudo bpftool link
```## TODO
- [ ] Add tests
- [ ] Add github actions
- [ ] Update bpf maps on reload
- [ ] Add monitoring
- [ ] Add structured logging
- [ ] Background Health checks for unhealthy targets.
- [ ] Filter requests from the start from unverified sources.
- [ ] Encryption/decryption support for requests.
- [ ] Caching support.
- [ ] Support batch request instead of just single request.
- [ ] Add security by adding authentication for client requests using certificates.## Inspiration
[eBPF summit 2020](https://ebpf.io/summit-2020-slides/eBPF_Summit_2020-Lightning-Jakub_Sitnicki-Steering_connections_to_sockets_with_BPF_socke_lookup_hook.pdf)