From owner-freebsd-pf@FreeBSD.ORG Tue Jan 1 23:35:42 2008 Return-Path: Delivered-To: freebsd-pf@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 8BF7916A41B for ; Tue, 1 Jan 2008 23:35:42 +0000 (UTC) (envelope-from mksmith@adhost.com) Received: from mail-defer01.adhost.com (mail-defer01.adhost.com [216.211.128.150]) by mx1.freebsd.org (Postfix) with ESMTP id 5D1A113C4EE for ; Tue, 1 Jan 2008 23:35:42 +0000 (UTC) (envelope-from mksmith@adhost.com) Received: from mail-in08.adhost.com (mail-in08.adhost.com [10.211.128.141]) by mail-defer01.adhost.com (Postfix) with ESMTP id EC269ECF6F for ; Tue, 1 Jan 2008 15:18:46 -0800 (PST) (envelope-from mksmith@adhost.com) Received: from ad-exh01.adhost.lan (unknown [216.211.143.69]) by mail-in08.adhost.com (Postfix) with ESMTP id B189D8FC37; Tue, 1 Jan 2008 15:18:46 -0800 (PST) (envelope-from mksmith@adhost.com) Received: from [192.168.100.101] ([10.142.3.64]) by ad-exh01.adhost.lan with Microsoft SMTPSVC(6.0.3790.3959); Tue, 1 Jan 2008 15:18:46 -0800 Message-Id: From: Michael Smith To: Michael Zimmer In-Reply-To: Content-Type: text/plain; charset=US-ASCII; format=flowed; delsp=yes Content-Transfer-Encoding: 7bit Mime-Version: 1.0 (Apple Message framework v915) Date: Tue, 1 Jan 2008 15:18:45 -0800 References: X-Mailer: Apple Mail (2.915) X-OriginalArrivalTime: 01 Jan 2008 23:18:46.0084 (UTC) FILETIME=[A84EE040:01C84CCC] X-TM-AS-Product-Ver: SMEX-7.5.0.1243-5.0.1023-15640.002 X-TM-AS-Result: No--15.483500-5.000000-31 X-TM-AS-User-Approved-Sender: No X-TM-AS-User-Blocked-Sender: No Cc: freebsd-pf@freebsd.org Subject: Re: load-balancing, DNS X-BeenThere: freebsd-pf@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: "Technical discussion and general questions about packet filter \(pf\)" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 01 Jan 2008 23:35:42 -0000 Hello Michael: I think you want to use "reply-to" instead of "route-to" on load balance rules since you need it to go out the same interface it came in on. This will work in conjunction with any connection that has state, so make sure your DNS pass rule has keep-state. Try pass in quick on $int_if reply-to { ($ext_if1 $ext_gw1), ($ext_if2 $ext_gw2) } round-robin proto { tcp icmp udp } from 192.168.1.1/24 to any flags S/SA keep-state pass in quick on $int_if route-to { ($ext_if1 $ext_gw1), ($ext_if2 $ext_gw2) } round-robin sticky-address proto { tcp icmp udp } from any to any flags S/SA keep-state 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 Regards, Mike On Jan 1, 2008, at 1:32 PM, Michael Zimmer wrote: > > Hi everyone, > > I just installed pf on FreeBSD 6.2 for a firewall/NAT/load- > balancer ... but I'm having some trouble. I'm pretty sure that it > isn't actually splitting the outgoing traffic (trying to load- > balance over two uplinks), and the users are experiencing > intermittent trouble resolving DNS entries (and being silly users, > instead of reloading the page, they yell 'the Internet isn't > working!' and then use that as a reason for reeeeaaally long lunches). > > The workstations behind the FreeBSD box are mostly running some > flavor of Windows; static private IPs, gateway set to the BSD box, > primary DNS set to the DNS server of the ISP on uplink #1, secondary > to the ISP on uplink #2. I can force it to use either connection > successfully, but not both. > > > Thanks in advance for any help. Happy New Year! > > -mike > > > Here's my setup: > > dc1 is uplink #1; dc0 is uplink #2 (via a DSL modem on IP pass- > through); bfe0 links to the internal network. > > resolv.conf: > > domain x.comnameserver 66.z.z.z # DNS provided by ISP #1 > > ------------- > rc.conf: > > defaultrouter="66.x.x.x" #this is the upstream gateway on > dc0gateway_enable="YES"hostname="x.x.com"ifconfig_dc0="inet > 68.y.y.y netmask 255.255.255.0" > ifconfig_dc1="inet 66.y.y.y netmask > 255.255.255.224"ifconfig_bfe0="inet 192.168.1.1 netmask > 255.255.255.0" > > inetd_enable="YES"linux_enable="YES"sshd_enable="YES"usbd_enable="YES" > > ntpdate_enable="YES"ntpdate_hosts="0.us.pool.ntp.org" > > nfs_reserved_port_only="NO" > pf_enable="YES"pf_rules="/etc/ > pf.conf"pf_flags=""pflog_enable="YES"pflog_logfile="/var/log/ > pflog"pflog_flags="" > --------------- > pf.conf: > > ext_if1 > ="dc0"ext_if2="dc1"int_if="bfe0"ext_gw1="68.x.x.x"ext_gw2="66.x.x.x" > internal_net="192.168.1.1/24" > tcp_services="( 22 )"icmp_types="( 8 )" > #tablestable persist file "/etc/blocktable" > > set block-policy drop > set limit { states 20000, frags 5000 } > > set skip on lo0 > > scrub in all > > nat on $ext_if1 from $internal_net to any -> ($ext_if1)nat on > $ext_if2 from $internal_net to any -> ($ext_if2) > block in from any to anyblock out from any to any > pass out on $int_if from any to $internal_net keep state > pass in quick on $ext_if1 proto tcp from any to 68.y.y.y port 22 > flags S/SA keep state #ext_if1 > > #allows ICMP outboundpass in quick on $int_if proto icmp all keep > state > #allows incoming from client's serverpass in quick on {$ext_if1, > $ext_if2} proto tcp from a.b.c.d/32pass in quick on {$ext_if1, > $ext_if2} proto tcp from a.b.c.d/30 > > #blocks to inside-to-outside here#spoofsblock in quick on $int_if > from any to 172.16.0.0/12block in quick on $int_if from any to > 10.0.0.0/8block in quick on $int_if from any to 169.254.0.0/16block > in quick on $int_if from any to 192.168.0.0/16block in quick on > $int_if from any to 204.152.64.0/23block in quick on $int_if from > any to 224.0.0.0/3 > > # traffic from inside goes straight outpass in quick on $int_if from > 192.168.1.0/24 to $int_ifpass out on $ext_if1 from [address of > $ext_if1] to any flags S/SA keep statepass out on $ext_if2 from > [address of $ext_if2] to any flags S/SA keep state > > #load balancing ...? > pass in quick on $int_if route-to { ($ext_if1 $ext_gw1), ($ext_if2 > $ext_gw2) } round-robin proto { tcp icmp udp } from 192.168.1.1/24 > to any flags S/SA modulate statepass in quick on $int_if route-to > { ($ext_if1 $ext_gw1), ($ext_if2 $ext_gw2) } round-robin proto { tcp > icmp udp } from any to any flags S/SA modulate state > pass out on $ext_if1 route-to ($ext_if2 $ext_gw2) from $ext_if2 to > anypass out on $ext_if2 route-to ($ext_if1 $ext_gw1) from $ext_if1 > to any > > _________________________________________________________________ > Get the power of Windows + Web with the new Windows Live. > http://www.windowslive.com?ocid=TXT_TAGHM_Wave2_powerofwindows_122007_______________________________________________ > freebsd-pf@freebsd.org mailing list > http://lists.freebsd.org/mailman/listinfo/freebsd-pf > To unsubscribe, send any mail to "freebsd-pf-unsubscribe@freebsd.org"