Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/minj-ae/tinyxdp
- Owner: minj-ae
- License: agpl-3.0
- Created: 2024-05-27T05:18:30.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-05-28T00:52:10.000Z (8 months ago)
- Last Synced: 2024-05-28T10:27:37.003Z (8 months ago)
- Topics: ddos-mitigation, ebpf, endpoint-security, xdp
- Language: C
- Homepage:
- Size: 17.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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