iptables includes a module that allows
administrators to inspect and restrict connections to services
available on an internal network using a method called connection tracking. Connection tracking stores
connections in a table, which allows administrators to allow or
deny access based on the following connection states:
-
NEW — A packet requesting a new
connection, such as an HTTP request.
-
ESTABLISHED — A packet that is
part of an existing connection.
-
RELATED — A packet that is
requesting a new connection but is part of an existing connection,
such as passive FTP connections where the connection port is 20,
but the transfer port can be any unused port 1024 or higher.
-
INVALID — A packet that is not
part of any connections in the connection tracking table.
You can use the stateful functionality of iptables connection tracking with any network
protocol, even if the protocol itself is stateless (such as UDP).
The following example shows a rule that uses connection tracking to
forward only the packets that are associated with an established
connection:
iptables -A FORWARD -m state --state ESTABLISHED,RELATED -j ALLOW
|