DragonFly net will be down for a little while today to renumber
Matthew Dillon
dillon at apollo.backplane.com
Tue Feb 12 09:39:18 PST 2013
: I am moving the DragonFly network to a new VPN (pointing at a new colo)
: to deal with the IP routing issues people are having.
:
: I will attempt to get the boxes up on both VPNs first before I tear
: down the old one (in a few days) but there may be network outages anyway.
Here's an update. I was forced to scrap the old VPN, the dual-homed
setup was just not stable enough and I was having problems with loops
in the bridging code when I tried to integrate Avalon into the new
network (Avalon physically sits in the old colo). I was also having
a lot of trouble getting the default route to work properly, since
there are actually three default routes that have to be messed around
with (10/8, OldIPBlock, NewIPBlock).
The network has now been entirely switched over to the new IP block
(199.233.90/24) homed in the new colo. The old IP block (69.163.100/24)
has been disconnected, though the machines in the old colo still use
some of the old IPs.
Basically our current set-up is:
San Jose colo - Avalon
Freemont colo - Kronos
My Home - Crater, Leaf, Monster, etc.
(dual-homed to both Comcast and AT&T U-Verse)
Latency between the colos is around ~1-2ms. Latency over Comcast
to Crater, Leaf, etc from the Freemont colo is ~25-40ms or so
unloaded.
The two colo's and Home are bridged using OpenVPN. However, due to
numerous issues I couldn't dual-home both IP blocks and I couldn't
complete a circle so the bridging is currently a Star pattern centered
on the Freemont colo.
A little later this year we will be buying a blade server to place in
the Freemont colo and all DragonFly infrastructure will be moved onto
blades.
----
Problems Encountered
* The if_bridge code couldn't handle the circle. There are bugs in
my STP code which caused issues. Basically I was trying to multi-home
two separate internet-routable IP networks on the same bridge in a
circular pattern and it got seriously confused.
* Generally speaking, multi-homed bridged machines can create serious
problems with bridges due to the fact that bridging is MAC-based and
not IP-based. So when one machine is multi-homed and has more
than one default route (going to different targets across the bridge),
and is handling packets for both targets simultaniously, the bridge can
get very seriously confused on how to bridge replies to the packet.
* Most DFly machines use a 10/8 network for their primary IP address
and internet/other IP addresses are aliases. They default to
NAT-out when not bound to their internet IPs. IPFW rules adjust
the default route when the packets are sourced/targetted at the
machine's internet-routable IP address.
This means that there are actually several default routes depending
on the source IP. The 10/8 network has its own default route which
points to the NAT box, and the routable IP block(s) have their own
default routes which generally point to a host across the bridge.
* Chicken-and-egg issues with IPFW and PF packet filter ordering.
Since neither supports reinjection of the packet (that's a feature
that PF sorely needs). IPFW comes first, then PF.
Basically the default route can be changed with IPFW prior to a
packet feeding into PF, but for some reason either cannot be changed
safely within PF or the change occurs in the wrong order relative
to other rules.
* Discovered a bug when combining a NAT rule with a change in the
default route. DragonFly wanted to send an ICMP IP Redirect for
the pre-NAT packet in addition to translating the packet and
transmitting a post-NAT packet. That created a bit of a mess.
(fortunately it can be turned off with a sysctl, but it's still
a bug).
So, three not so wonderful glitches which hopefully we'll be able to work
on this year. We need better handling of multiple default routes,
we need to track down and fix the improper ICMP IP Redirect, and we
need to fix the if_bridge's STP protocol in multi-homed configurations.
--
There may be some more down-time this afternoon as I clean up the
DNS infrastructure.
-Matt
Matthew Dillon
<dillon at backplane.com>
More information about the Users
mailing list