iptables 防火墙非管理

参考文档:
https://www.frozentux.net/iptables-tutorial/cn/iptables-tutorial-cn-1.1.19.html
https://www.cnblogs.com/chenny7/p/3922834.html

netfilter/iptabels应用程序,被认为是Linux中实现包过滤功能的第四代应用程序。
netfilter/iptables包含在2.4以后的内核中,它可以实现FirewallNAT(网络地址转换)和数据包的分割等功能。
netfilter工作在内核中,由一些信息包过滤表组成,这些表包含内核用来控制信息包过滤处理的规则集;
iptables工作在用户态空间,它使插入、修改和除去信息包过滤表中的规则变得容易。

iptables读取流入和流出数据包的报头,将它们与规则集(Rule set)相比较:
1、将可接受的数据包从一个网卡转发至另一个网卡;
2、对被拒绝的数据包,可以丢弃或按照所定义的方式来处理。

根据规则所处理的信息包类型,可以将规则分组在链中:
1、处理入站信息包的规则被添加到INPUT链中;
2、处理出站信息包的规则被添加到OUTPUT链中;
3、处理正在转发的信息包的规则被添加到FORWARD链中;

这三个链是基本信息包过滤表中内置的缺省主链。另外,还有其他许多可用的链的类型(如PREROUTING和POSTROUTING),以及提供用户自定义的链。

每个链都可以有一个策略,它定义“缺省目标”,也就是要执行的缺省操作,当信息包与链中的任何规则都不匹配时,执行此操作。

iptables有多张table(如下),每个table又包含若干chains,每条chain是由一组rules构成;

image

以本地为目的的包

以本地为源的包

转发的包

filter表
INPUT链针对目的是本地的包;
OUTPUT链过滤本地生成的包;
FORWARD链过滤不是本地产生的,且目的地也不是本地的包(即转发的包);

nat表
属于一个流的包只会经过nat表一次,如果第一个包被允许做nat,其后的包会自动被做相同的处理;所以nat表不要做任何过滤操作;
PREROUTING链的主要作用是包刚刚到达firewall时改变它的目的地址;
POSTROUTING链的主要作用是包离开firewall时改变其源地址;
OUTPUT链改变本地产生的包的目的地址;

mangle表
不建议在mangle表里做任何过滤;

iptables 命令格式
对来自某个源地址,到达某个目的地址或具有特定协议类型的信息包要做些什么指令、规则控制信息包的过滤,

可以通过使用iptables系统提供的命令去建立这些规则,并将其添加到内核空间特定信息包过滤表内的链中。

关于添加、去除、编辑规则的命令,一般语法如下:

iptables [-t table] command [chain] [rules] [-j target]

[-t table] :用来指明使用的表, 可以为: filter(缺省表), nat 和 mangle。

command 表明iptables命令要做什么,比如:

-L <CHAIN>, -S <CHAIN>
列出链中的所有规则;输出格式不同

-I <CHAIN>, -A <CHAIN>
插入一条规则,I此规则会作为链的第一条规则;A则会在最后一条

-D <CHAIN> N, -D <CHAIN>
删除一条规则,可以明确指明规则内容,也可以用N指出链中的第N条

-F <CHAIN>, -Z <CHAIN>
F清除链中的所有规则,不指明链,则清除所有链;Z则是只清除计数器,不清除规则

-P <CHAIN>
指定某条链的默认动作,ACCEPT、DROP或REJECT等

chain 表明操作的链,例如INPUT、OUTPUT、FORWARD等;

rules 匹配的包规则,同一条规则里的多个条件是“与”的关系,比如:

-p, --protocol
协议匹配,如 -p tcp

-s, --src, --source
来源匹配,如 -s 202.108.37.49

-d, --dst, --destination
目的匹配,如 -d 172.16.115.117

-i, --in-interface
入网卡接口匹配,如 -i eth0

-o, --out-interface
出网卡接口匹配,如 -o eth1

--sport, --source-port
来源端口匹配(tcp或udp),如 --sport 80;也可以用端口范围,如 --sport 135:139

--dport, --destination-port
目的端口匹配(tcp或udp),如 --dport 80;同样支持端口范围

--tcp-flags
tcp状态匹配,如 --tcp-flags RST RST

-m mac --mac-source
mac地址匹配,如 -m mac --mac-source 00:1E:C9:B0:53:D2

-m multiport --source-port , --destination-port
多端口匹配,如-m multiport --destination-port 80,443

-m iprange
简单的指定ip范围。用--src-range或--dst-range匹配,如 -m iprange --src-range 192.168.1.33-192.168.1.50

-m time
指定匹配时间(UTC),可以使用--datestart、--datestop、--timestart或--timestop等参数。如 -m time --datestart 2014-01-01T00:00:00 --datestop 2014-12-31T23:59:59 。注意时间是UTC时间。

target: 是由规则指定的操作。 包括下面几种:
-j ACCEPT:

接收信息包(允许它前往目的地),并且将停止遍历chain;

-j DROP

默默丢弃包(对方不知道);

-j REJECT

拒绝包,会发RST明确通知对方拒绝;

-j SNAT

源地址转换,如 -j SNAT --to 61.135.152.194

-j MASQUERADE
类似SNAT,但是根据默认路由转换,适用于动态ip(不需要指明转换后的地址)

-j DNAT
进行目的地址转换,如 -j DNAT --to-destination 192.168.0.254

-j REDIRECT
(对于tcp和udp)进行端口重定向,如 -j REDIRECT --to-ports 8080

此外还有, RETURN, LOG, MARK, MIRROR, MAQUERADE等。

image

应用场景

1、查看已添加的规则

iptables -L -n

iptables -t nat -L

2、保存

/etc/rc.d/init.d/iptables save

3、删除已添加的规则

iptables -L -n --line-numbers

4、清除已有的规则

iptables -F 清除filter表的所有规则

iptables -X 清除filter表中用户自定义的规则

iptables -Z

5、开放指定的端口

iptables -A INPUT -p tcp --dport 21 -j ACCEPT

6、阻止一个IP连接本机

iptables -t filter -A INPUT -s 192.168.1.5 -i eth0 -j DROP

7、端口转发

iptables -t nat -A PREROUTING -d 1.2.3.4 -p tcp -m tcp --dport 81 -j DNAT --to-destination192.168.0.2:8180

iptables -t nat -A POSTROUTING -s 192.168.0.0/255.255.0.0 -d 192.168.0.2 -p tcp -m tcp --dport 8180 -j SNAT --to-source 192.168.0.1

8、

丢弃RST包

iptables -I INPUT -p tcp --sport 80 --tcp-flags RST RST -j DROP

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,869评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,716评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,223评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,047评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,089评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,839评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,516评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,410评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,920评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,052评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,179评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,868评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,522评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,070评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,186评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,487评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,162评论 2 356