func (sm *SubnetManager) LeaseRenewer(cancel chan bool) { for { dur := sm.leaseExp.Sub(time.Now()) - renewMargin select { case <-time.After(dur): sm.mtx.RLock() attrBytes, err := json.Marshal(&sm.myLease.Attrs) sm.mtx.RUnlock() if err != nil { log.Error("Error renewing lease (trying again in 1 min): ", err) dur = time.Minute continue } sm.mtx.RLock() resp, err := sm.registry.UpdateSubnet(sm.myLease.Network.StringSep(".", "-"), string(attrBytes), subnetTTL) sm.mtx.RUnlock() if err != nil { log.Error("Error renewing lease (trying again in 1 min): ", err) dur = time.Minute continue } sm.leaseExp = *resp.Expiration log.Info("Lease renewed, new expiration: ", sm.leaseExp) dur = sm.leaseExp.Sub(time.Now()) - renewMargin case <-cancel: return } } }
func (vb *VXLANBackend) handleSubnetEvents(batch subnet.EventBatch) { for _, evt := range batch { switch evt.Type { case subnet.SubnetAdded: log.Info("Subnet added: ", evt.Lease.Network) if evt.Lease.Attrs.BackendType != "vxlan" { log.Warningf("Ignoring non-vxlan subnet: type=%v", evt.Lease.Attrs.BackendType) continue } var attrs vxlanLeaseAttrs if err := json.Unmarshal(evt.Lease.Attrs.BackendData, &attrs); err != nil { log.Error("Error decoding subnet lease JSON: ", err) continue } if err := vb.dev.AddL2(neigh{IP: evt.Lease.Attrs.PublicIP, MAC: net.HardwareAddr(attrs.VtepMAC)}); err != nil { log.Error("Error adding L2 entry: ", err) } if err := vb.dev.AddL3(neigh{IP: evt.Lease.Network.IP, MAC: net.HardwareAddr(attrs.VtepMAC)}); err != nil { log.Error("Error adding L3 entry: ", err) } if err := vb.dev.AddRoute(evt.Lease.Network); err != nil { log.Error("Error adding route: ", err) } case subnet.SubnetRemoved: log.Info("Subnet removed: ", evt.Lease.Network) if evt.Lease.Attrs.BackendType != "vxlan" { log.Warningf("Ignoring non-vxlan subnet: type=%v", evt.Lease.Attrs.BackendType) continue } var attrs vxlanLeaseAttrs if err := json.Unmarshal(evt.Lease.Attrs.BackendData, &attrs); err != nil { log.Error("Error decoding subnet lease JSON: ", err) continue } if err := vb.dev.DelRoute(evt.Lease.Network); err != nil { log.Error("Error deleting route: ", err) } if len(attrs.VtepMAC) > 0 { if err := vb.dev.DelL2(neigh{IP: evt.Lease.Attrs.PublicIP, MAC: net.HardwareAddr(attrs.VtepMAC)}); err != nil { log.Error("Error deleting L2 entry: ", err) } if err := vb.dev.DelL3(neigh{IP: evt.Lease.Network.IP, MAC: net.HardwareAddr(attrs.VtepMAC)}); err != nil { log.Error("Error deleting L3 entry: ", err) } } default: log.Error("Internal error: unknown event type: ", int(evt.Type)) } } }
func makeSubnetManager() *subnet.SubnetManager { var registryFn func() (subnet.Registry, error) client := disc.NewClientWithURL(opts.discoverdURL) registryFn = func() (subnet.Registry, error) { return discoverd.NewRegistry(client, "flannel") } for { reg, err := registryFn() if err != nil { log.Error("Failed to create subnet registry: ", err) time.Sleep(time.Second) continue } sm, err := subnet.NewSubnetManager(reg) if err == nil { return sm } log.Error("Failed to create SubnetManager: ", err) time.Sleep(time.Second) } }
func (rb *HostgwBackend) handleSubnetEvents(batch subnet.EventBatch) { for _, evt := range batch { switch evt.Type { case subnet.SubnetAdded: log.Infof("Subnet added: %v via %v", evt.Lease.Network, evt.Lease.Attrs.PublicIP) if evt.Lease.Attrs.BackendType != "host-gw" { log.Warningf("Ignoring non-host-gw subnet: type=%v", evt.Lease.Attrs.BackendType) continue } route := netlink.Route{ Dst: evt.Lease.Network.ToIPNet(), Gw: evt.Lease.Attrs.PublicIP.ToIP(), LinkIndex: rb.extIface.Index, } if err := netlink.RouteAdd(&route); err != nil { log.Errorf("Error adding route to %v via %v: %v", evt.Lease.Network, evt.Lease.Attrs.PublicIP, err) continue } case subnet.SubnetRemoved: log.Info("Subnet removed: ", evt.Lease.Network) if evt.Lease.Attrs.BackendType != "host-gw" { log.Warningf("Ignoring non-host-gw subnet: type=%v", evt.Lease.Attrs.BackendType) continue } route := netlink.Route{ Dst: evt.Lease.Network.ToIPNet(), Gw: evt.Lease.Attrs.PublicIP.ToIP(), LinkIndex: rb.extIface.Index, } if err := netlink.RouteDel(&route); err != nil { log.Errorf("Error deleting route to %v: %v", evt.Lease.Network, err) continue } default: log.Error("Internal error: unknown event type: ", int(evt.Type)) } } }
func run(be backend.Backend, sm *subnet.SubnetManager, exit chan int) { var err error defer func() { if err == nil || err == task.ErrCanceled { exit <- 0 } else { log.Error(err) exit <- 1 } }() iface, ipaddr, err := lookupIface() if err != nil { return } if iface.MTU == 0 { err = fmt.Errorf("Failed to determine MTU for %s interface", ipaddr) return } log.Infof("Using %s as external interface", ipaddr) sn, err := be.Init(iface, ipaddr, opts.httpPort, opts.ipMasq) if err != nil { return } writeSubnetFile(sn) notifyWebhook(sn) if err = httpServer(sm, ipaddr.String(), opts.httpPort); err != nil { err = fmt.Errorf("error starting HTTP server: %s", err) return } if opts.discoverdURL != "" { disc.NewClientWithURL(opts.discoverdURL).AddServiceAndRegister("flannel", net.JoinHostPort(ipaddr.String(), opts.httpPort)) } log.Infof("%s mode initialized", be.Name()) be.Run() }
func (sm *SubnetManager) AcquireLease(attrs *LeaseAttrs, cancel chan bool) (ip.IP4Net, error) { for { sn, err := sm.acquireLeaseOnce(attrs, cancel) switch { case err == nil: log.Info("Subnet lease acquired: ", sn) return sn, nil case err == task.ErrCanceled: return ip.IP4Net{}, err default: log.Error("Failed to acquire subnet: ", err) } select { case <-time.After(time.Second): case <-cancel: return ip.IP4Net{}, task.ErrCanceled } } }