Iptables小总结

本文涉及的产品
公网NAT网关,每月750个小时 15CU
简介:

信息包过滤过程:

wKiom1M3dgzBMlSoAADC2j3VMHw577.jpg


1、iptables四表五链

四个表:

filter:用于过滤

nat:用于nat功能(端口映射,地址映射等)

mangle:用于对特定数据包的修改

raw:一般不让iptables做数据包的链接跟踪处理

五个链:

INPUT:匹配目的地址为本机的

OUTPUT:向外转发的

FORWARD:需要经过本机的数据包

PREROUTING:路由前,用于修改目的地址(DNAT)

POSTROUTING:路由后,用于修改源地址(SNAT)

2、常用操作命令

命令格式:iptables  [-t表]  -命令  匹配  操作

-A(append):追加一条规则

-I(insert):插入一条规则

-D(delete):删除一条规则,例如:iptables –D INPUT 3,删除第三条规则

-F(flush):清空规则

-L(list):列出规则,使用-vnL来显示比较好

-P(policy):设置某链默认规则

3、匹配条件

-i:进入接口

-o:出去接口

-s:来源地址,例如:-s 192.168.1.0/24,可单IP

-d:目的地址

-p:协议类型(tcp、udp、icmp)

--sport:来源端口,例如:--sport 1000:,匹配源端口1000以上的,也可以1000:3000指定范围

--dport:目的端口

4、动作

ACCEPT:允许数据包通过

DROP:阻止数据包通过

REJECT:拒绝数据包通过,并返回报错信息

SNAT:应用nat表的POSTROUTING链,进行源地址转换,可单个、一组IP

DNAT:应用nat表的PREROUTING链,进行目的地址转换,可单个、一组IP

MASQUERADE:动态源地址转换,动态IP时使用

例如ADSL拨号上网:iptables –t nat –A POSTROUTING –s 192.168.1.0/24 –o pppo –j MASQUERADE

5、附加模块

state:包状态匹配,例如:iptables -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT

NEW 第一个数据包状态,RELATED 该数据包已经或将启动新的连接,当一个连接和某个已处于ESTABLISHED状态的连接有关系时,就是RELATED状态,像FTP连接。ESTABLISHED 已建立连接的状态,INVALID 该数据包与已知的连接都不相关联)

mac:来源MAC地址匹配

limit:包速率匹配

multiport:多端口匹配,端口以逗号分隔

6、防止小量攻击

防CC、DOS攻击,限制每个IP的并发连接数

#允许已经建立连接的访问 

iptables -A INPUT -p tcp -m state --state ESTABLISHED,RELATED -j ACCEPT   

#--connlimit-above 30  限制并发连接数

iptables -I INPUT -p tcp --syn --dport 80 -m connlimit --connlimit-above 30 -j REJECT  

防DDOS攻击,限制每个IP每秒并发连接数:

iptables -A INPUT -p tcp --syn -m limit --limit 1/s --limit-burst 3 -j ACCEPT

iptables -A FORWARD -p tcp --syn -m limit --limit 1/s -j ACCEPT  

7、配置NAT映射

先开启路由转发:

echo "1" > /proc/sys/net/ipv4/ip_forward  #临时生效

内网访问外网(SNAT):

iptables –t nat -A POSTROUTING -s [内网IP或网段] -j SNAT --to [公网IP]

#内网服务器要指向防火墙内网IP为网关

公网访问内网(DNAT)(公网端口映射内网端口):

iptables –t nat -A PREROUTING -d [对外IP] -p tcp --dport [对外端口] -j DNAT --to [内网IP:内网端口]

#内网服务器要配置防火墙内网IP为网关,否则数据包回不来。另外,这里不用配置SNAT,因为系统服务会根据数据包来源再返回去。

将本机80端口转发到本地8080端口:

iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-ports 8080

8、用户基本配置示例

iptables -F

iptables -t nat -F

iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

iptables -A INPUT -p tcp -m multiport --dports 22,80,8080 -j ACCEPT

iptables -A INPUT -p udp -m multiport --dports 53 -j ACCEPT

iptables -A INPUT -s 192.168.1.0/24 -j ACCEPT

iptables -A INPUT -p icmp -j DROP

iptables -A INPUT -i lo -j ACCEPT   #允许来自于lo接口的数据包,如果没有此规则,你将不能通过127.0.0.1访问本地服务

iptables -P INPUT DROP

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
目录
相关文章
|
网络协议 Shell
iptables 详解
iptables 详解
91 0
|
7月前
|
网络协议 网络安全
Iptables小总结
Iptables小总结
|
安全 网络协议 Linux
扒一下一直不求甚解的 iptables
iptables 是用于配置 Linux 2.4.x 及更高版本包过滤规则集的用户空间命令行程序。它针对系统管理员。 由于网络地址转换 (NAT) 也是从包过滤规则集配置的,iptables 也用于此。 iptables 包还包括 ip6tables。ip6tables 用于配置 IPv6 包过滤器。
扒一下一直不求甚解的 iptables
|
Kubernetes 网络协议 算法
Iptables 介绍与使用
Iptables 介绍与使用
455 0
Iptables 介绍与使用
|
网络安全 Linux Apache
|
网络协议 Linux 网络安全
|
网络协议 算法 网络安全
|
网络协议 网络安全