1. 程式人生 > >CentOS防火牆的配置方法詳解【iptables】

CentOS防火牆的配置方法詳解【iptables】

CentOS6/7系統是基於linux中的,它的防火牆其實就是iptables了。

下面我來介紹在CentOS防火牆iptables的配置教程,希望此教程對各位朋友會有所幫助。

iptables是與Linux核心整合的IP資訊包過濾系統,其自帶防火牆功能,我們在配置完伺服器的角色功能後,需要修改iptables的配置。

配置CentOS和Ubuntu等Linux伺服器時需要對伺服器的iptables進行配置,以下是iptables常見的幾種配置方法。

1.檢視當前所有的iptables配置

程式碼如下複製程式碼

iptables -L -n

2.新增允許INPUT訪問規則,以下時常見服務的埠設定,如果需要拒絕訪問,則將ACCEPT改為DROP即可

程式碼如下複製程式碼

#SSH

iptables -A INPUT -p tcp --dport 22 -j ACCEPT

#HTTP

iptables -A INPUT -p tcp --dport 80 -j ACCEPT

iptables -A INPUT -p tcp --dport 8080 -j ACCEPT

#HTTPS

iptables -A INPUT -p tcp --dport 443 -j ACCEPT

#POP3

iptables -A INPUT -p tcp --dport 110 -j ACCEPT

#SMTP

iptables -A INPUT -p tcp --dport 25 -j ACCEPT

#FTP

iptables -A INPUT -p tcp --dport 21 -j ACCEPT

iptables -A INPUT -p tcp --dport 20 -j ACCEPT

#DNS

iptables -A INPUT -p tcp --dport 53 -j ACCEPT

3.新增使用IP限制INPUT訪問規則,這裡拿SSH為例,192.168.0.100為允許的IP

程式碼如下複製程式碼

#DELETE

iptables -D INPUT -p tcp --dport 22 -j ACCEPT

#ADD

iptables -A INPUT -s 192.168.0.100 -p tcp --dport 22 -j ACCEPT

4.儲存iptables的設定,修改完規則後記得儲存

程式碼如下複製程式碼

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

5.重啟iptables

程式碼如下複製程式碼

service iptables restart

6.開啟/關閉 開機啟動

程式碼如下複製程式碼

chkconfig iptables on

chkconfig iptables off

7 .開啟iptables的配置檔案:

程式碼如下複製程式碼

vi /etc/sysconfig/iptables

通過/etc/init.d/iptables status命令查詢是否有開啟80埠,如果沒有可通過兩種方式處理:

8.修改vi /etc/sysconfig/iptables命令新增使防火牆開放80埠

程式碼如下複製程式碼

-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT

9.關閉/開啟/重啟防火牆

程式碼如下複製程式碼

/etc/init.d/iptables stop

#start 開啟

#restart 重啟

10.永久性關閉防火牆

程式碼如下複製程式碼

chkconfig --level 35 iptables off

/etc/init.d/iptables stop

iptables -P INPUT DROP

11.開啟主動模式21埠

程式碼如下複製程式碼

iptables -A INPUT -p tcp --dport 21 -j ACCEPT

12.開啟被動模式49152~65534之間的埠

程式碼如下複製程式碼

iptables -A INPUT -p tcp --dport 49152:65534 -j ACCEPT

iptables -A INPUT -i lo -j ACCEPT

iptables -A INPUT -m state --state ESTABLISHED -j ACCEPT

注意:

一定要給自己留好後路,留VNC一個管理埠和SSh的管理埠

需要注意的是,你必須根據自己伺服器的情況來修改這個檔案。

全部修改完之後重啟iptables:

程式碼如下複製程式碼

service iptables restart

你可以驗證一下是否規則都已經生效:

程式碼如下複製程式碼

iptables -L

通過文章的介紹,我們清楚的知道了CentOS下配置iptables防火牆的過程

在虛擬機器搭建web後,主機訪問不了,具體情況如下:

1。本機能ping通虛擬機器

2。虛擬機器也能ping通本機

3。虛擬機器能訪問自己的web

4。本機無法訪問虛擬己的web

這時應該要想到是防火牆的原因。關於防火牆的設定網上很多例子,也有點複雜,在這裡我就不介紹了。這裡只解決如何讓主機能夠通過ip訪問虛擬機器的web。

程式碼如下複製程式碼

[[email protected] ~]# vi /etc/sysconfig/iptables

Firewall configuration written by system-config-firewall

Manual customization of this file is not recommended.

*filter

:INPUT ACCEPT [0:0]

:FORWARD ACCEPT [0:0]

:OUTPUT ACCEPT [0:0]

-A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

-A INPUT -p icmp -j ACCEPT

-A INPUT -i lo -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT

-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT

-A INPUT -j REJECT --reject-with icmp-host-prohibited

-A FORWARD -j REJECT --reject-with icmp-host-prohibited

COMMIT

注意上面紅色的一行。80埠是預設的web埠。22為ssh的埠(可通過ssh連線虛擬機器了)。

重啟防火牆讓剛才的修改生效。

程式碼如下複製程式碼

[[email protected] ~]# /etc/init.d/iptables restart

這時,你再在主機上通過ip訪問虛擬機器的web,應該就可以了。