You’ll find that most if not all guides on how to block DDoS attacks using iptables use the filter table and the INPUT chain for anti-DDoS rules. That’s why you want to make sure that you can process and block as many packets per second as possible. Most TCP-based DDoS attack types use a high packet rate, meaning the sheer number of packets per second is what causes the server to go down. If you want to block a DDoS attack with iptables, performance of the iptables rules is extremely important. We’re going to explain why your iptables rules suck to stop DDoS and not teach you how to use iptables. Of course, we’re still missing an explanation of iptables targets (ACCEPT, DROP, REJECT, etc.), but we’re assuming that if you’re reading this article, you already know how to deal with iptables. Applies to packets that leave the serverĭepending on what kind of packets you want to block or modify, you select a certain iptables table and a chain that the selected table supports.Applies to packets that the server sends (locally generated).Applies to packets that are being routed through the server.Applies to packets destined to a local socket.Applies to packets that enter the network interface card (NIC).Each of these tables supports a different set of iptables chains. Raw: This table’s purpose is mainly to exclude certain packets from connection tracking using the NOTRACK target.Īs you can see there are four different tables on an average Linux system that doesn’t have non-standard kernel modules loaded. Mangle: The mangle table is used to modify or mark packets and their header information. If a packet creates a new connection, the nat table gets checked for rules. NAT: This table is used for Network Address Translation (NAT). IPtables Tablesįilter: The filter table is the default and most commonly used table that rules go to if you don’t use the -t ( –table) option. There are different tables for different purposes. Iptables is a command line tool used to set up and control the tables of IP packet filter rules. To understand why your current iptables rules to prevent DDoS attacks suck, we first have to dig into how iptables works. Most commonly it’s used to block destination ports and source IP addresses. Iptables can be used to filter certain packets, block source or destination ports and IP addresses, forward packets via NAT and a lot of other things. It’s the default firewall management utility on Linux systems – everyone working with Linux systems should be familiar with it or have at least heard of it. Netfilter iptables (soon to be replaced by nftables) is a user-space command line utility to configure kernel packet filtering rules developed by netfilter. If they are able to reach your server, there isn’t much you can do against those multi-Gbit/s attacks except to move to a DDoS protected network. The only mitigation approach that makes sense against these types of attacks is to block them at the edge or core network or even at the carrier already.ĭid you know we now offer 1Gbps unmetered VPS plans with DDoS protection in Chicago, Illinois and Bucharest, Romania? Most UDP-based attacks are amplified reflection attacks that will exhaust the network interface card of any common server. We’ll only cover protection from TCP-based attacks. However, it isn’t impossible to filter most bad traffic at line rate using iptables! While one can do a lot with iptables to block DDoS attacks, there isn’t a way around actual hardware firewalls ( we recently reviewed RioRey DDoS mitigation hardware) to detect and stop large DDoS floods. If you just want to protect your online application from DDoS attacks, you can use our remote protection, a VPS with DDoS protection or a DDoS protected bare metal server. Block Packets From Private Subnets (Spoofing).The Best Linux Kernel Settings to Mitigate DDoS.