Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/minj-ae/tinyxdp

Strict traffic overload control XDP program for endpoint, suitable for getting rid of DDoS packets
https://github.com/minj-ae/tinyxdp

ddos-mitigation ebpf endpoint-security xdp

Last synced: 1 day ago
JSON representation

Strict traffic overload control XDP program for endpoint, suitable for getting rid of DDoS packets

Awesome Lists containing this project

README

        

# tinyXDP
> Traffic ratelimit, tinyXDP!

The purpose is to mitigate DDoS by clearing traffic exceeding the rate limit through tinyXDP in a space that can be processed before the kernel. It's superfast, even dropped packets will not log.

![](https://github.com/minj-ae/tinyXDP/assets/65323308/e1dee385-11f2-4dad-b379-e9855b4d21d5)

## Requirements

### Debian

```sh
sudo apt install clang llvm libelf-dev libpcap-dev build-essential libc6-dev-i386 linux-perf linux-headers-$(uname -r) bpftool tcpdump
```

## Usage example

To attach tinyXDP, type

```sh
make
make load
make attach INTERFACE=yourinterfacename
```
To detach tinyXDP, type

```sh
make unload
make detach INTERFACE=yourinterfacename
```

To whitelist server endpoint IP, type
```sh
make ip ACTION=add IP=x.x.x.x
```

To remove IP from whitelist, type
```sh
make ip ACTION=remove IP=x.x.x.x
```

## Development setup

Install `Requirements`

```sh

```

## Release History

* 0.1.0
* The first proper release
* CREATE: **TCP** ratelimit

* 0.2.0
* ADD: **TCP** conntrack
* ADD: **TCP** bogon FLAG check
* ADD: endpoint ip whitelist adder

* 0.2.1
* ADD: **TCP** conntrack advanced
* EDIT: Change bogon FLAG check logic

* 0.3.0
* ADD: GRE support
* ADD: TCP Strict overload logic
* ADD: UDP Strict overload logic based detection

## Meta

Minjae Kim – [minj.ae](https://minj.ae) – [email protected]

Distributed under the GPLv3 license. See ``LICENSE`` for more information.

[github.com/minj-ae](https://github.com/minj-ae)

## Contributing

1. Fork it ()
2. Create your feature branch (`git checkout -b feature/fooBar`)
3. Commit your changes (`git commit -am 'Add some fooBar'`)
4. Push to the branch (`git push origin feature/fooBar`)
5. Create a new Pull Request