iptables命令是Linux上常用的防火墻軟件,是netfilter項(xiàng)目的一部分。可以直接配置,也可以通過(guò)許多前端和圖形界面配置。
語(yǔ)法
iptables(選項(xiàng))(參數(shù))
選項(xiàng)
-t<表>:指定要操縱的表;
-A:向規(guī)則鏈中添加條目;
-D:從規(guī)則鏈中刪除條目;
-i:向規(guī)則鏈中插入條目;
-R:替換規(guī)則鏈中的條目;
-L:顯示規(guī)則鏈中已有的條目;
-F:清楚規(guī)則鏈中已有的條目;
-Z:清空規(guī)則鏈中的數(shù)據(jù)包計(jì)算器和字節(jié)計(jì)數(shù)器;
-N:創(chuàng)建新的用戶自定義規(guī)則鏈;
-P:定義規(guī)則鏈中的默認(rèn)目標(biāo);
-h:顯示幫助信息;
-p:指定要匹配的數(shù)據(jù)包協(xié)議類型;
-s:指定要匹配的數(shù)據(jù)包源ip地址;
-j<目標(biāo)>:指定要跳轉(zhuǎn)的目標(biāo);
-i<網(wǎng)絡(luò)接口>:指定數(shù)據(jù)包進(jìn)入本機(jī)的網(wǎng)絡(luò)接口;
-o<網(wǎng)絡(luò)接口>:指定數(shù)據(jù)包要離開本機(jī)所使用的網(wǎng)絡(luò)接口。
iptables命令選項(xiàng)輸入順序:
iptables -t 表名 <-A/I/D/R> 規(guī)則鏈名 [規(guī)則號(hào)] <-i/o 網(wǎng)卡名> -p 協(xié)議名 <-s 源IP/源子網(wǎng)> --sport 源端口 <-d 目標(biāo)IP/目標(biāo)子網(wǎng)> --dport 目標(biāo)端口 -j 動(dòng)作
表名包括:
raw:高級(jí)功能,如:網(wǎng)址過(guò)濾。
mangle:數(shù)據(jù)包修改(QOS),用于實(shí)現(xiàn)服務(wù)質(zhì)量。
net:地址轉(zhuǎn)換,用于網(wǎng)關(guān)路由器。
filter:包過(guò)濾,用于防火墻規(guī)則。
規(guī)則鏈名包括:
INPUT鏈:處理輸入數(shù)據(jù)包。
OUTPUT鏈:處理輸出數(shù)據(jù)包。
PORWARD鏈:處理轉(zhuǎn)發(fā)數(shù)據(jù)包。
PREROUTING鏈:用于目標(biāo)地址轉(zhuǎn)換(DNAT)。
POSTOUTING鏈:用于源地址轉(zhuǎn)換(SNAT)。
動(dòng)作包括:
accept:接收數(shù)據(jù)包。
DROP:丟棄數(shù)據(jù)包。
REDIRECT:重定向、映射、透明代理。
SNAT:源地址轉(zhuǎn)換。 DNAT:目標(biāo)地址轉(zhuǎn)換。
MASQUERADE:IP偽裝(NAT),用于ADSL。
LOG:日志記錄。
實(shí)例 清除已有iptables規(guī)則
iptables -F
iptables –X
iptables -Z
開放指定的端口
iptables -A INPUT -s 127.0.0.1 -d 127.0.0.1 -j ACCEPT #允許本地回環(huán)接口(即運(yùn)行本機(jī)訪問(wèn)本機(jī))
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT #允許已建立的或相關(guān)連的通行 iptables -A OUTPUT -j ACCEPT #允許所有本機(jī)向外的訪問(wèn)
iptables -A INPUT -p tcp --dport 22 -j ACCEPT #允許訪問(wèn)22端口
iptables -A INPUT -p tcp --dport 80 -j ACCEPT #允許訪問(wèn)80端口
iptables -A INPUT -p tcp --dport 21 -j ACCEPT #允許ftp服務(wù)的21端口
iptables -A INPUT -p tcp --dport 20 -j ACCEPT #允許FTP服務(wù)的20端口
iptables -A INPUT -j reject #禁止其他未允許的規(guī)則訪問(wèn)
iptables -A FORWARD -j REJECT #禁止其他未允許的規(guī)則訪問(wèn)
屏蔽IP
iptables -I INPUT -s 123.45.6.7 -j DROP #屏蔽單個(gè)IP的命令
iptables -I INPUT -s 123.0.0.0/8 -j DROP #封整個(gè)段即從123.0.0.1到123.255.255.254的命令 iptables -I INPUT -s 124.45.0.0/16 -j DROP #封IP段即從123.45.0.1到123.45.255.254的命令 iptables -I INPUT -s 123.45.6.0/24 -j DROP #封IP段即從123.45.6.1到123.45.6.254的命令是 查看已添加的iptables規(guī)則 iptables -L -n -v
iptables -L -n –v