歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Unix知識 >> 關於Unix

FreeBSD連載:設置和使用ipfilter


設置和使用ipfilter
  雖然ipfw/natd已經是相當強大的網絡地址轉換及防火牆系統,然而它還是有一定的缺點存在。其中最重要的一個缺點是natd是使用守護進程的方法來進行地址轉換,因為它沒有運行在內核中,而是通過divert socket 來和內核通信,這種方式雖然比較靈活,但效率顯然要低一些。
  另外,natd的功能還不能滿足有些要求,natd能做靜態地址轉換和使用一個偽裝地址為多個內部地址服務,但其不能從一個給定的地址池中,為內部地址自動分配IP地址。畢竟natd是一個較早的網絡地址轉換工具,當前的發展已經比較遲緩。但是由於ipfw是FreeBSD系統的一部分,並且過濾和地址轉換是由不同的部分來完成的,結構清晰,因此對於大部分情況都很適合,因此一般仍應使用ipfw/natd。
  如果ipfw/natd不能滿足使用者的需要,能避免ipfw/natd缺點的另一個網絡地址轉換和數據包過濾的工具是ipfilter。雖然FreeBSD是其支持的主要系統,但它其實是一個支持多平台的獨立軟件,不僅能運行在FreeBSD上,也能運行在其他多種Unix系統中。由於它被包括進FreeBSD基本系統中,因此在FreeBSD 下配置ipfilter同樣也非常輕松。
  由於ipfilter與ipfw同為在內核級對IP數據包進行處理的系統,因此他們相互沖突,不能同時並存在一個內核內,否則內核的TCP/IP功能就不能正常執行。為了使用ipfilter,就需要重新定制內核,刪除所有 IPFIREWALL的設置,而添加IPFILTER的設置。
#options IPFIREWALL
#options IPDIVERT
options IPFILTER
options IPFILTER_LOG


  使用新內核啟動系統之後,如果本地計算機的網絡功能正常,此時再使用ipfw就會報告錯誤。這就能使用ipfilter 來設置包過濾和網絡地址轉換了。
設置地址轉換
  為了在ipfilter下設置網絡地址轉換,首先要創建一個地址轉換設置文件,例如/etc/ipflter .nat。與ipfw/natd的相似,最基本的用法為使用一個外部地址來轉換所有內部地址,此時必須進行端口轉換,因此ipfilter.nat中應該包含的NAT規則為:
  map fxp1 192.168.3.0/24 -> 202.102.245.60/32 portmap tcp/udp 10000:65000
  這個設置中,首先使用map關鍵字指明是進行地址轉換的設置,此後的fxp1為連接外部網絡的網絡界面,在這個網絡界面上執行數據包的IP地址和端口地址轉換,第三個參數為進行轉換的內部地址的范圍,此後跟隨的一個-> 符號表示進行地址轉換,第五個參數為要轉換為的外部地址,當指定子網掩碼長度為32時就表示這只是一個主機而非子網范圍,後面portmap關鍵字對tcp/udp協議進行端口轉換,其使用的映射端口范圍為在10000到65000之間,也可以對tcp或udp協議分別指定轉換端口的范圍。
  如果使用者擁有的不僅是一個主機,而是一個具備多個合法IP地址的子網,這樣就能設置使用地址池,為內部向外連接的計算機動態分配合法的外部IP地址,這樣的設置更為簡單,因為不需要指定portmap進行地址轉換。
  map fxp1 192.168.3.0/24 -> 202.102.245.0/26
  顯然內部計算機的數量顯然要多於系統擁有的合法地址的數量,上例中內部地址最多254個,而合法的外部地址僅僅有62個,這樣如果向外連接的計算機一多,必然出現地址資源用光的問題。因此動態分配IP一般和端口轉換結合起來,以避免出現地址消耗完畢的問題。
  map規則是用於轉換外出數據包的源地址,使得被轉換後的地址好象是從外部地址中發起的。而另一個規則rdr 用於轉換數據包中的目的地址,這樣就能使得一個數據包被轉發到某個特定計算機上進行處理,這可用於構建端口映射關系。
  rdr fxp1 202.102.245.60 port ftp -> 192.168.3.2 port ftp
  上面的規則將指定ipfilter在fxp1網絡界面上將發送給202.102.245.60,端口為ftp 的數據包,轉換為發送給內部地址192.168.3.2。
  rdr的另一個重要用途是可以用以構建透明的代理服務器,普通代理服務器都需要在客戶機上進行設置,如果不進行設置,客戶機將直接訪問Internet上的計算機而不通過代理服務器,然而防火牆可以將這些應用請求轉發給代理服務器,完成代理工作。此時對外界發送請求是在內部網絡界面fxp0上發起的,因此也要在這裡進行地址轉換,而使用0.0.0.0/0 代表對所有目的地址,並且是80端口的浏覽請求都轉發到127.0.0.1上去,而127.0.0.1 必須運行代理服務器軟件,以提供代理服務。
  rdr fxp0 0.0.0.0/0 port 80 -> 127.0.0.1 port 80
  雖然不是所有的應用代理服務都能使用透明代理的方法來減輕客戶設置的負擔,但絕大多數代理完全可以使用這種方法,使得客戶不需要修改軟件設置,就能利用代理服務器,而代理服務器具備大量的緩沖區,能夠節約內部網絡的Internet 訪問流量並加速Internet訪問速度。
map fxp1 192.168.3.0/24 -> 202.102.245.0/26 portmap tcp/udp 10000:65000
map fxp1 192.168.3.0/24 -> 202.102.245.0/26
rdr fxp1 202.102.245.60 port ftp -> 192.168.3.2 port ftp


  在這樣的設置下,tcp和udp在地址資源消耗完畢之後將進行端口轉換,而其他協議,如icmp,將直接進行地址轉換而不必進行端口轉換。此後就可以將這個轉換規則加入系統中,需要執行ipnat命令:
# ipnat -C


  當前使用-C參數用於清除現有的轉換規則,-f用於從配置文件中讀取轉換規則。設置了轉換規則之後,就可以使用-l參數查看當前設置的轉換規則和已經激活的轉換關系。
# ipnat -l
List of active MAP/Redirect filters:
map fxp1 192.168.3.0/24 -> 202.102.245.0/26 portmap tcp/udp 10000:65000
map fxp1 192.168.3.0/24 -> 202.102.245.0/26
rdr fxp1 202.102.245.60/32 port 21 -> 192.168.3.2 port 21 tcp
List of active sessions:
RDR 192.168.3.2 21 <- -> 202.102.245.60 21 [202.102.245.25 35635] 863
992 0 407
MAP 192.168.3.2 1024 <- -> 202.102.245.60 10000 [202.102.245.25 9999] 8639
93 0 1f09


設置包過濾
block in log quick all with short
block in log quick all with ipopts


  block參數用於屏蔽符合過濾條件的數據包,in代表數據包的方向,標識從網絡上或其他網絡界面上發送到某個網絡界面上的數據包,log用於指出該規則過濾的數據包應被記錄下來,quick指示ipfilter進行快速過濾處理,符合這個規則的數據包將立即丟棄,all with short標識不完整的IP數據包,數據包的長度太小就沒有包含合法的源地址或目標地址,從而無法被ipfilter識別,all with ipopts標志本身帶有路由數據的IP數據包,這些IP數據包由於包含自己的路由信息,因此可能會帶來網絡安全問題。
  這兩句設置用於過濾可能會帶來安全問題的短數據包或具備路由信息的數據包。
pass in on fxp0 all
pass out on fxp0 all
pass in on lo0 all
pass out on lo0 all


  pass用於指定數據包可以通過,out與in相反,標識從網絡界面向網絡上或其他網絡界面發送的數據包,而on fxp0或on lo0標識進行處理的網絡界面。這裡的設置允許內部網絡界面、loopback網絡界面可以自由發送和接收數據包。
block in log on fxp1 all
block out log on fxp1 all


  為了安全起見,除了明確指定可以發送和接收的數據包之外,屏蔽其余的外部網絡界面進行數據發送和接收。
block in log quick on fxp1 from 10.0.0.0/8 to any
block in log quick on fxp1 from 192.168.0.0/16 to any
block in log quick on fxp1 from 172.16.0.0/12 to any
block in log quick on fxp1 from 127.0.0.0/8 to any


  上面的設置明確屏蔽具備內部網絡地址的數據包被轉發到外部網絡去,由於ipfilter中地址轉換和包過濾是在同一個系統中完成的,因此不必擔心它們會發生沖突問題。
pass out log on fxp1 proto icmp all keep state
pass out log on fxp1 proto tcp/udp from any to any keep state


  proto用於指定不同的協議,通常可以設置為tcp, udp和icmp。這兩行設置允許TCP, UDP, ICMP協議的數據包可以向外發送出去,keep state用於標識建立TCP連接之後的數據包,或者ICMP、UDP的回應數據包,以允許回應數據包能發送回內部網絡。
pass in quick on fxp1 proto tcp from any to any port = ftp-data keep state
pass in quick on fxp1 proto tcp from any port = ftp-data to any port > 1023 keep state


  ftp中將打開額外的端口以進行數據傳輸,這兩個設置允許對ftp數據端口的數據包能夠進行轉發。
block return-rst in log on fxp1 proto tcp from any to any flags S/SA
block return-icmp(net-unr) in log on fxp1 proto udp from any to any


  對於其他tcp連接請求,防火牆回應一個RST數據包關閉連接,S/SA標識TCP數據包的標志,S為Syn, A為Ack,而S/SA表示對Syn和Ack中的Syn標志進行檢查,這類數據包是用於設定連接的數據包。對UDP請求,防火牆回應網絡不可達到的ICMP包。
  上面的例子將屏蔽外部計算機發向網絡內部的數據包,但允許內部向外的發起網絡訪問。如果要允許外部網絡對內的訪問,就必須增加其他pass in規則,以使得過濾規則能適應更復雜的情況。為了使上面的設置生效,必須將過濾規則加入到內核中去,這需要使用ipf命令。
# ipf -Fa


# ipfstat
input packets: blocked 227 passed 116210 nomatch 68219 counted 0
output packets: blocked 0 passed 74586 nomatch 20316 counted 0
input packets logged: blocked 227 passed 24883
output packets logged: blocked 0 passed 17153
packets logged: input 0 output 0
log failures: input 25028 output 17139
fragment state(in): kept 0 lost 0
fragment state(out): kept 0 lost 0
packet state(in): kept 1 lost 0
packet state(out): kept 14 lost 8
ICMP replies: 160 TCP RSTs sent: 9
Result cache hits(in): 47523 (out): 53694
IN Pullups succeeded: 0 failed: 0
OUT Pullups succeeded: 0 failed: 0
Fastroute successes: 0 failures: 0
TCP cksum fails(in): 0 (out): 0
Packet log flags set: (0x10000000)
packets passed through filter


  雖然在規則中指定了log選項,但是缺省時候syslogd並不會記錄ipfilter發送的信息。符合規則的數據記錄並沒有真正被發送到系統日志記錄中,必須使用ipmon打開記錄功能。
# ipmon -s -n -x


local0.* /var/log/ipfilter.log


  為了不讓ipfilter的記錄發送到/var/log/messages等其他日志文件中,可以在/var/log/messags設置行中添加一個記錄local.none。
  此後,使用touch創建ipfilter.log文件,並重新啟動syslogd,就能在/var/log/ipfilter.log中正確記錄過濾記錄了。當一切都設置完畢之後,就能將ipf和ipnat這兩個設置命令放入系統啟動文件rc.local,以便每次系統自動啟動都能執行防火牆設置。
Copyright © Linux教程網 All Rights Reserved