From f26b2e62694d1eed0ba849fe2fbb6dae17fb6c5d Mon Sep 17 00:00:00 2001 From: Santhosh Manohar Date: Tue, 7 Feb 2017 11:12:38 -0800 Subject: [PATCH] Ignore previous serf user events to avoid wrong fdb programming Signed-off-by: Santhosh Manohar --- drivers/overlay/ov_network.go | 3 +++ drivers/overlay/ov_serf.go | 8 +++++--- osl/neigh_linux.go | 2 ++ 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/drivers/overlay/ov_network.go b/drivers/overlay/ov_network.go index 122c3f6b1b..f64a10704a 100644 --- a/drivers/overlay/ov_network.go +++ b/drivers/overlay/ov_network.go @@ -644,6 +644,9 @@ func (n *network) watchMiss(nlSock *nl.NetlinkSocket) { } if neigh.IP.To4() == nil { + if neigh.HardwareAddr != nil { + logrus.Debugf("Miss notification, l2 mac %v", neigh.HardwareAddr) + } continue } diff --git a/drivers/overlay/ov_serf.go b/drivers/overlay/ov_serf.go index 53c59b4df2..49ba09de79 100644 --- a/drivers/overlay/ov_serf.go +++ b/drivers/overlay/ov_serf.go @@ -73,7 +73,7 @@ func (d *driver) serfJoin(neighIP string) error { if neighIP == "" { return fmt.Errorf("no neighbor to join") } - if _, err := d.serfInstance.Join([]string{neighIP}, false); err != nil { + if _, err := d.serfInstance.Join([]string{neighIP}, true); err != nil { return fmt.Errorf("Failed to join the cluster at neigh IP %s: %v", neighIP, err) } @@ -94,8 +94,8 @@ func (d *driver) notifyEvent(event ovNotify) { } func (d *driver) processEvent(u serf.UserEvent) { - logrus.Debugf("Received user event name:%s, payload:%s\n", u.Name, - string(u.Payload)) + logrus.Debugf("Received user event name:%s, payload:%s LTime:%v \n", u.Name, + string(u.Payload), uint64(u.LTime)) var dummy, action, vtepStr, nid, eid, ipStr, maskStr, macStr string if _, err := fmt.Sscan(u.Name, &dummy, &vtepStr, &nid, &eid); err != nil { @@ -146,6 +146,7 @@ func (d *driver) processQuery(q *serf.Query) { return } + logrus.Debugf("Sending peer query resp %v", fmt.Sprintf("%s %s %s", peerMac.String(), net.IP(peerIPMask).String(), vtep.String())) q.Respond([]byte(fmt.Sprintf("%s %s %s", peerMac.String(), net.IP(peerIPMask).String(), vtep.String()))) } @@ -173,6 +174,7 @@ func (d *driver) resolvePeer(nid string, peerIP net.IP) (net.HardwareAddr, net.I return nil, nil, nil, fmt.Errorf("failed to parse mac: %v", err) } + logrus.Debugf("Received peer query response, mac %s, vtep %s, mask %s", macStr, vtepStr, maskStr) return mac, net.IPMask(net.ParseIP(maskStr).To4()), net.ParseIP(vtepStr), nil case <-time.After(time.Second): diff --git a/osl/neigh_linux.go b/osl/neigh_linux.go index 673522ad63..e875f6ab64 100644 --- a/osl/neigh_linux.go +++ b/osl/neigh_linux.go @@ -5,6 +5,7 @@ import ( "fmt" "net" + "github.com/Sirupsen/logrus" "github.com/vishvananda/netlink" ) @@ -96,6 +97,7 @@ func (n *networkNamespace) AddNeighbor(dstIP net.IP, dstMac net.HardwareAddr, op nh := n.findNeighbor(dstIP, dstMac) if nh != nil { + logrus.Debugf("Neighbor entry already present for IP %v, mac %v", dstIP, dstMac) // If it exists silently return return nil }