func (c *Controller) purgeStaleServiceRefs(fip *types.FloatingIp, refs contrail.ReferenceList, podIdMap map[string]*api.Pod) { update := false for _, ref := range refs { vmi, err := types.VirtualMachineInterfaceByUuid(c.client, ref.Uuid) if err != nil { glog.Errorf("%v", err) continue } instanceRefs, err := vmi.GetVirtualMachineRefs() if err != nil { glog.Errorf("%v", err) continue } if len(instanceRefs) == 0 { continue } if _, ok := podIdMap[instanceRefs[0].Uuid]; ok { continue } glog.V(3).Infof("Delete reference from pod %s to %s", ref.Uuid, fip.GetFloatingIpAddress()) fip.DeleteVirtualMachineInterface(vmi.GetUuid()) update = true } if update { err := c.client.Update(fip) if err != nil { glog.Errorf("%v", err) } } }
func (c *Controller) updateServicePublicIP(service *api.Service) (*types.FloatingIp, error) { var publicIp *types.FloatingIp = nil var err error resourceName := publicIpResourceName(service) if service.Spec.ExternalIPs != nil { // Allocate a floating-ip from the public pool. publicIp, err = c.networkMgr.LocateFloatingIp( c.networkMgr.GetPublicNetwork(), resourceName, service.Spec.ExternalIPs[0]) } else if service.Spec.Type == api.ServiceTypeLoadBalancer { publicIp, err = c.networkMgr.LocateFloatingIp(c.networkMgr.GetPublicNetwork(), resourceName, "") if err == nil { status := api.LoadBalancerStatus{Ingress: []api.LoadBalancerIngress{ api.LoadBalancerIngress{IP: publicIp.GetFloatingIpAddress()}, }} if !reflect.DeepEqual(service.Status.LoadBalancer, status) { service.Status.LoadBalancer = status _, err := c.kube.Services(service.Namespace).Update(service) if err != nil { glog.Infof("Update service %s LB status: %v", service.Name, err) } } } } return publicIp, err }