iptables是linux系統自帶的防火牆,功能強大,學習起來須要一段時間,下面是一些習iptables的時候的記錄。若是iptables不熟悉的話能夠用apf,是一款基於iptables的防火牆,挺好用的。linux
一,安裝並啓動防火牆centos
[root@linux ~]# /etc/init.d/iptables start
當咱們用iptables添加規則,保存後,這些規則以文件的形勢存在磁盤上的,以centos爲例,文件地址是/etc/sysconfig/iptables,咱們能夠經過命令的方式去添加,修改,刪除規則,也能夠直接修改/etc/sysconfig/iptables這個文件就好了。tcp
二,添加防火牆規則post
1,添加filter表學習
[root@linux ~]# iptables -A INPUT -p tcp -m tcp --dport 21 -j ACCEPT //開放21端口
出口我都是開放的iptables -P OUTPUT ACCEPT,因此出口就不必在去開放端口了。ip
2,添加nat表get
[root@linux ~]# iptables -t nat -A POSTROUTING -s 192.168.10.0/24 -j MASQUERADE
將源地址是 192.168.10.0/24 的數據包進行地址假裝input
3,-A默認是插入到尾部的,能夠-I來插入到指定位置it
[root@linux ~]# iptables -I INPUT 3 -p tcp -m tcp --dport 20 -j ACCEPT [root@linux ~]# iptables -L -n --line-number Chain INPUT (policy DROP) num target prot opt source destination 1 ACCEPT all -- 0.0.0.0/0 0.0.0.0/0 2 DROP icmp -- 0.0.0.0/0 0.0.0.0/0 icmp type 8 3 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:20 //-I指定位置插的 4 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:22 5 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:80 6 ACCEPT all -- 0.0.0.0/0 0.0.0.0/0 state RELATED,ESTABLISHED 7 DROP all -- 0.0.0.0/0 0.0.0.0/0 state INVALID,NEW 8 ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:21 //-A默認插到最後Chain FORWARD (policy ACCEPT) num target prot opt source destination Chain OUTPUT (policy ACCEPT) num target prot opt source destination
三,查下iptable規則io
1,查看filter表
[root@linux ~]# iptables -L -n --line-number |grep 21 //--line-number能夠顯示規則序號,在刪除的時候比較方便 5 ACCEPT tcp -- 192.168.1.0/24 0.0.0.0/0 tcp dpt:21
若是不加-t的話,默認就是filter表,查看,添加,刪除都是的
2,查看nat表
[root@linux ~]# iptables -t nat -vnL POSTROUTING --line-number Chain POSTROUTING (policy ACCEPT 38 packets, 2297 bytes) num pkts bytes target prot opt in out source destination 1 0 0 MASQUERADE all -- * * 192.168.10.0/24 0.0.0.0/0
四,修改規則
[root@linux ~]# iptables -R INPUT 3 -j DROP //將規則3改爲DROP
五,刪除iptables規則
[root@linux ~]# iptables -D INPUT 3 //刪除input的第3條規則 [root@linux ~]# iptables -t nat -D POSTROUTING 1 //刪除nat表中postrouting的第一條規則 [root@linux ~]# iptables -F INPUT //清空 filter表INPUT全部規則 [root@linux ~]# iptables -F //清空全部規則 [root@linux ~]# iptables -t nat -F POSTROUTING //清空nat表POSTROUTING全部規則
六,設置默認規則
[root@linux ~]# iptables -P INPUT DROP //設置filter表INPUT默認規則是 DROP
全部添加,刪除,修改後都要保存起來,/etc/init.d/iptables save.上面只是一些最基本的操做,要想靈活運用,還要必定時間的實際操做。