centos中iptables的使用方法與執行個體

來源:互聯網
上載者:User


查看ip串連數:

netstat -ntu | awk '{print $5}' | cut -d: -f1 | sort | uniq -c | sort -n

1、安裝iptables防火牆

如果沒有安裝iptables需要先安裝,CentOS執行:

yum install iptables

Debian/Ubuntu執行:

apt-get install iptables

2、清除已有iptables規則

iptables -F
iptables -X
iptables -Z

3、開放指定的連接埠

#允許本地迴環介面(即運行本機訪問本機)
iptables -A INPUT -s 127.0.0.1 -d 127.0.0.1 -j ACCEPT
# 允許已建立的或相關連的通行
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
#允許所有本機向外的訪問
iptables -A OUTPUT -j ACCEPT
# 允許訪問22連接埠
iptables -A INPUT -p tcp --dport 22 -j ACCEPT
#允許訪問80連接埠
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
#允許FTP服務的21和20連接埠
iptables -A INPUT -p tcp --dport 21 -j ACCEPT
iptables -A INPUT -p tcp --dport 20 -j ACCEPT
#如果有其他連接埠的話,規則也類似,稍微修改上述語句就行
#禁止其他未允許的規則訪問
iptables -A INPUT -j REJECT  (注意:如果22連接埠未加入允許規則,SSH連結會直接斷開。)
iptables -A FORWARD -j REJECT

4、屏蔽IP

#屏蔽單個IP的命令是
iptables -I INPUT -s 123.45.6.7 -j DROP
#封整個段即從123.0.0.1到123.255.255.254的命令
iptables -I INPUT -s 123.0.0.0/8 -j DROP
#封IP段即從123.45.0.1到123.45.255.254的命令
iptables -I INPUT -s 124.45.0.0/16 -j DROP
#封IP段即從123.45.6.1到123.45.6.254的命令是
iptables -I INPUT -s 123.45.6.0/24 -j DROP
4、查看已添加的iptables規則
iptables -L -n
v:顯示詳細資料,包括每條規則的匹配包數量和匹配位元組數
x:在 v 的基礎上,禁止自動單位換算(K、M)
n:只顯示IP地址和連接埠號碼,不將ip解析為網域名稱

5、刪除已添加的iptables規則

將所有iptables以序號標記顯示,執行:

iptables -L -n --line-numbers
比如要刪除INPUT裡序號為8的規則,執行:

iptables -D INPUT 8

6、iptables的開機啟動及規則儲存

CentOS上可能會存在安裝好iptables後,iptables並不開機自啟動,可以執行一下:

chkconfig --level 345 iptables on
將其加入開機啟動。

CentOS上可以執行:service iptables save儲存規則。

另外更需要注意的是Debian/Ubuntu上iptables是不會儲存規則的。

需要按如下步驟進行,讓網卡關閉是儲存iptables規則,啟動時載入iptables規則:

建立/etc/network/if-post-down.d/iptables 檔案,添加如下內容:

#!/bin/bash
iptables-save > /etc/iptables.rules
執行:chmod +x /etc/network/if-post-down.d/iptables 添加執行許可權。

建立/etc/network/if-pre-up.d/iptables 檔案,添加如下內容:

#!/bin/bash
iptables-restore < /etc/iptables.rules
執行:chmod +x /etc/network/if-pre-up.d/iptables 添加執行許可權。


儲存儲存.寫入到/etc/sysconfig/iptables檔案裡

iptables-save >/etc/sysconfig/iptables

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

service iptables save

 

iptables -L -n

iptables –t nat –L :顯示nat表的中的設定

 

iptables -F 清除預設表filter中的所有規則鏈的規則

 

iptables -X 清除預設表filter中使用者自定鏈中的規則

 

-D刪除鏈裡面的某一條規則:

iptables -L

iptables –D INPUT 3 刪除INPUT鏈上的第3條規則。

 

插入規則 iptables -I 插入到第一行,成為第一個規則

 

iptables-save >/etc/sysconfig/iptables

 

設定鏈的規則

iptables -p INPUT DROP

 

iptables -p OUTPUT ACCEPT

 

iptables -p FORWARD DROP

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.