分享
 
 
 

[收藏整理] 理解iptables 2

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

原文:2000.6.6 by Jephe Wu

网址:http://www.linuxforum.net/docnew/showthreaded.php?Cat=&Board=sys&Number=348&page=0&view=collapsed&sb=5&o=all&fpart=

iptables 是有状态的(stateful)。

有状态的意思是指如果一个包是对从防火墙原先发出去的包的回复,则自动不用检查任何

规则就立即允许回复包进入并返回给请求者,这样我们不用设置许多规则定义就可实现应

有的功能,在新的内核中使用这种有状态的能力是强烈地被推荐的,那么如何打开并使用

这种功能呢? 见下图。 (图二)

我们假定某公司有如下图所示的典型的internet连接方案:

_______

10.0.0.2 | |

|PC | (10.0.0.1)eth1| |eth0(1.2.3.4)

B|___|_ ___________________|防火墙 |---------Internet

(LAN: 10.0.0.0/24) | A |

|_______|

可使用下面的规则集使用iptables的有状态的能力并打开IP伪装功能。

1 modprobe ip_tables

2 echo 1 > /proc/sys/net/ipv4/ip_forward

3 iptables -F INPUT

4 iptables -F FORWARD

5 iptables -F POSTROUTING -t nat

6 iptables -P FORWARD DROP

7 iptables -A FORWARD -s 10.0.0.0/24 -j ACCEPT

8 iptables -A FORWARD -i eth0 -m state --state ESTABLISHED,RELATED -j ACCEPT

9 iptables -t nat -A POSTROUTING -o eth0 -s 10.0.0.0/24 -j MASQUERADE

10 iptables -A INPUT -p tcp -i eth0 --syn --dport 80 -j ACCEPT

11 iptables -A INPUT -p tcp -i eth0 --syn -j DROP

注:

1. 当使用redhat 的模块化内核时,装入ip_tables模块后,以后的命令将根据需要自行

装入需要的模块。

另外注意,如果你装入了ipchains或者ipfwadm模块,则不能再装入iptables模块,可用

rmmod命令移走它 们再装入iptables模块。在redhat下,可用ntsysv移走ipchains和

iptables标记重启后运行上面的命令。

或者放入/etc/rc.d/rc.local中自动运行。

2. 第二行打开IP转发功能。

3. 第三四五行清除INPUT,FORWARD和POSTROUTING键规则

4. 第六行设置默认转发策略是DROP,当一个包被转发转则应用但不能应用到任何一条转

发规则上则应用默认 规则。

5. 第七行转发本网段的机器到任何地方去的包。

6. 第八行利用了有状态的能力,只要是对先前从防火墙外部接口出去的请求包的回复,允许。

ESTABLISHED是指TCP连接,RELATED是指象主动FTP,ICMP ping请求等,当回复包到达

时,实际上是检查文 件 /proc/net/ip_conntrack看是否在里面,如果在表中,则不检

查任何链,包允许通过。

7. 第九行打开IP伪装能力,从eth0出去的包被重写源地址后伪装出去,是源地址SNAT的

特例。这里要注意的是 -o eth0, 而不是 -i eth0,在iptables中,从一个接口出去的

包用 -o,进来的包用 -i

8. 第十行说明如果这台防火墙也是WEB服务器,则允许外部的新建立的请求且目标端口为

80的包可以进入

9. 第十一行对不是目标端口是80的所求TCP新的连接请求包,拒绝进入。

注: NAT 与 FORWARD 链的关系

a. 不管执行任何NAT,对包过滤规则看到的源和目的地址是真实的源和目的地址,尽管在

执行IP伪装(DNAT)时 会对包进行地址重写,这一点你可以从文件 /proc/net/ip_conntrack中看到。

b. 如果我们没有利用iptables的有状态的能力,象上面的情况,要是允许网段

10.0.0.0/24中的机器可以IP伪装的话,我们不得不加上一条转发规则 iptables -A

FORWARD -d 10.0.0.0/24 -j ACCEPT,否则对伪装包的回复不会通过转发链回复给内部

机器,因为回复包需要通过转发链。

注: 如何证明仅仅一个规则链被应用了?

在以前的ipchains中一个包要经过input,forward,output链才能从防火墙送出到

internet,现在使用iptables,仅仅一个链被应用,你可以加入下面的规则测试

iptables -A INPUT -s 10.0.0.2/24 -j DROP

上面的这行在iptables中仅仅是指任何本网段的机器当目标就是防火墙时被拒绝,但绝不

影响NAT和转发包,

这在以前的ipchains中是不可能的。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有