跳到主要內容

PF的Policy Routing(Load Balance)

這幾天希望把防火牆合併為一台,但仍要把user上網的ADSL與架站專線分開。如此一來就會有兩個Gateway,這種情況稱為 Policy Routing。有些人會希望申請兩條ADSL做Load Balance,也是利用Policy Routing達成。

若是用ipfw,gslin有寫過,在 http://ccca.nctu.edu.tw/~gslin/Documents/FreeBSD/load-balance.txt
Kernel的設定要加上以下指令,要啟動 IPFIREWALL_FORWARD 才有fwd的功能
options IPFIREWALL
options IPFIREWALL_VERBOSE
options IPFIREWALL_FORWARD
options IPDIVERT
options DUMMYNET
rc.conf也要加
firewall_enable="YES"
在 ipfw.rules 的語法
ipfw add fwd 211.72.1.1 ip from 192.168.1.0/24 to any out
ipfw add fwd 211.72.1.9 ip from 192.168.2.0/24 to any out
若使用FreeBSD 5.4版以上,建議直接改用 pf,FreeBSD的pf是移植自OpenBSD,因此有些文件說明實在是跟不上。所以要看OpenBSD的文件PF: Address Pools and Load Balancing
Kernel的設定:
device pf
device pflog
device pfsync
rc.conf加上
pf_enable="YES"
啟動pf後,使用以下語法:
pass out on $ext_if1 route-to ($ext_if2 $ext_gw2) from $ext_if2 to any
pass out on $ext_if2 route-to ($ext_if1 $ext_gw1) from $ext_if1 to any
細節參考四位兄的:FreeBSD + PF + Shell Scritp + Load Sharing + Redundant
另外,這裏有提到要用pfctl -e才能啟用,實在怪異。
相關概念可參考Policy Routing Book

Update :http://blog.pighead.cc/whsyu/2008/03/06/pf-in-freebsd7/ 有提到pf稍有改變,等鳥毅有機會再來測試。(不過,很有可能沒機會手動設定了,自從改用pfSense 後,可以簡單地設定Load Balance)

留言

這個網誌中的熱門文章

DBeaver 介面語言

DBeaver是我個人頗常用的一套跨平台Database管理工具,最近升級後發現Windows版本居然變成簡體中文,而且無法切換為英文。

Personal Bookmark

Java SE 6 + Firefox 2 UI 問題 As I do . Google拋棄了了SOAP API,浮想聯翩 https://www.gandi.net/ VS 2005 SP1中文版推出 Windows Vista中文版下載 ASP.NET 2.0網頁執行管線與快取原理 Cache 2.0快取架構與快取資料自動移除架構圖 flickr sync 分享與試用 SUN Looking Glass 3D圖形介面發布1.0 雅虎勵精圖治推動改革 Wait and see 國內某SOC疑遭駭客入侵 大砲開講 Very Important! 微軟公佈Vista安全程式介面草案 一窺Google開原碼庫房乾坤 qing is writing a dig girl net... wait and see

自然人憑證讀卡機驅動程式

鳥毅用的是第一代的自然人憑證讀卡機,EZ100PU(後來有同事買EZmini可以讀SIM卡似乎更好),每年報稅時用一次。 本來只是要申請些政府業務,一時之間找不到光碟,沒想到在 驅動程式下載 居然看到Linux和Mac的驅動程式,剩下的就是政府單位的網頁和程式應該改版了吧!!!