iptables是linux系统自带的防火墙,功能强大,学习起来需要一段时间,下面是一些习iptables的时候的记录。如果iptables不熟悉的话可以用apf,是一款基于iptables的防火墙,挺好用的。请参考:linux apf 防火墙 安装 配置
一,安装并启动防火墙
[root@linux~]#/etc/init.d/iptablesstart
当我们用iptables添加规则,保存后,这些规则以文件的形势存在磁盘上的,以centos为例,文件地址是/etc/sysconfig/iptables,我们可以通过命令的方式去添加,修改,删除规则,也可以直接修改/etc/sysconfig/iptables这个文件就行了。
二,添加防火墙规则
1,添加filter表
查看复制打印? [root@linux~]#iptables-AINPUT-ptcp-mtcp--dport21-jACCEPT//开放21端口
出口我都是开放的iptables -P OUTPUT ACCEPT,所以出口就没必要在去开放端口了。
2,添加nat表
[root@linux~]#iptables-tnat-APOSTROUTING-s192.168.10.0/24-jMASQUERADE
将源地址是 192.168.10.0/24 的数据包进行地址伪装
3,-A默认是插入到尾部的,可以-I来插入到指定位置
查看复制打印? [root@linux~]#iptables-IINPUT3-ptcp-mtcp--dport20-jACCEPT [root@linux~]#iptables-L-n--line-number ChainINPUT(policyDROP) numtargetprotoptsourcedestination 1ACCEPTall--0.0.0.0/00.0.0.0/0 2DROPicmp--0.0.0.0/00.0.0.0/0icmptype8 3ACCEPTtcp--0.0.0.0/00.0.0.0/0tcpdpt:20//-I指定位置插的 4ACCEPTtcp--0.0.0.0/00.0.0.0/0tcpdpt:22 5ACCEPTtcp--0.0.0.0/00.0.0.0/0tcpdpt:80 6ACCEPTall--0.0.0.0/00.0.0.0/0stateRELATED,ESTABLISHED 7DROPall--0.0.0.0/00.0.0.0/0stateINVALID,NEW 8ACCEPTtcp--0.0.0.0/00.0.0.0/0tcpdpt:21//-A默认插到最后 ChainFORWARD(policyACCEPT) numtargetprotoptsourcedestination ChainOUTPUT(policyACCEPT) numtargetprotoptsourcedestination
三,查下iptable规则
1,查看filter表
查看复制打印? [root@linux~]#iptables-L-n--line-number|grep21//--line-number可以显示规则序号,在删除的时候比较方便 5ACCEPTtcp--192.168.1.0/240.0.0.0/0tcpdpt:21
如果不加-t的话,默认就是filter表,查看,添加,删除都是的
2,查看nat表
[root@linux~]#iptables-tnat-vnLPOSTROUTING--line-number ChainPOSTROUTING(policyACCEPT38packets,2297bytes) numpktsbytestargetprotoptinoutsourcedestination 100MASQUERADEall--**192.168.10.0/240.0.0.0/0
四,修改规则
查看复制打印? [root@linux~]#iptables-RINPUT3-jDROP//将规则3改成DROP
五,删除iptables规则
查看复制打印? [root@linux~]#iptables-DINPUT3//删除input的第3条规则 [root@linux~]#iptables-tnat-DPOSTROUTING1//删除nat表中postrouting的第一条规则 [root@linux~]#iptables-FINPUT//清空filter表INPUT所有规则 [root@linux~]#iptables-F//清空所有规则 [root@linux~]#iptables-tnat-FPOSTROUTING//清空nat表POSTROUTING所有规则
六,设置默认规则
查看复制打印? [root@linux~]#iptables-PINPUTDROP//设置filter表INPUT默认规则是DROP
所有添加,删除,修改后都要保存起来,/etc/init.d/
iptables save.上面只是一些最基本的操作,要想灵活运用,还要一定时间的实际操作。
转自:/linux/1404.html