From d05fa3d5265dc7b78f536f48c4159f5a960ee1df Mon Sep 17 00:00:00 2001 From: Arjun Baindur Date: Wed, 19 Jan 2022 19:30:54 -0800 Subject: [PATCH 1/3] ip-reconciler: Use ContainerID instead of PodRef refactored on top of control loop changes by Doug --- pkg/reconciler/ip_test.go | 26 ++++++++++++++++---------- pkg/reconciler/iploop.go | 19 ++++++++++--------- 2 files changed, 26 insertions(+), 19 deletions(-) diff --git a/pkg/reconciler/ip_test.go b/pkg/reconciler/ip_test.go index 7e54d4e2d..c22e5e1dd 100644 --- a/pkg/reconciler/ip_test.go +++ b/pkg/reconciler/ip_test.go @@ -146,6 +146,7 @@ var _ = Describe("Whereabouts IP reconciler", func() { It("should report the dead pod's IP address as deleted", func() { deletedIPAddrs, err := reconcileLooper.ReconcileIPPools(context.TODO()) Expect(err).NotTo(HaveOccurred()) + // !bang this looks like a problem area... Expect(deletedIPAddrs).To(Equal([]net.IP{net.ParseIP("10.10.10.1")})) }) @@ -384,7 +385,8 @@ var _ = Describe("IPReconciler", func() { BeforeEach(func() { podRef := "default/pod1" - reservations := generateIPReservation(firstIPInRange, podRef) + containerID := "1234567890" + reservations := generateIPReservation(firstIPInRange, podRef, containerID) pool := generateIPPool(ipCIDR, podRef) orphanedIPAddr := OrphanedIPReservations{ @@ -404,7 +406,8 @@ var _ = Describe("IPReconciler", func() { Context("and they are actually multiple IPs", func() { BeforeEach(func() { podRef := "default/pod2" - reservations := generateIPReservation("192.168.14.2", podRef) + containerID := "1234567890" + reservations := generateIPReservation("192.168.14.2", podRef, containerID) pool := generateIPPool(ipCIDR, podRef, "default/pod2", "default/pod3") orphanedIPAddr := OrphanedIPReservations{ @@ -423,12 +426,14 @@ var _ = Describe("IPReconciler", func() { }) Context("but the IP reservation owner does not match", func() { - var reservationPodRef string + var reservationPodRef, reservationContainerID string BeforeEach(func() { - reservationPodRef = "default/pod2" + reservationPodRef = "default/pod1" + reservationContainerID = "1234567890" podRef := "default/pod1" - reservations := generateIPReservation(firstIPInRange, podRef) - erroredReservations := generateIPReservation(firstIPInRange, reservationPodRef) + podContainerID := "0987654321" + reservations := generateIPReservation(firstIPInRange, podRef, podContainerID) + erroredReservations := generateIPReservation(firstIPInRange, reservationPodRef, reservationContainerID) pool := generateIPPool(ipCIDR, podRef) orphanedIPAddr := OrphanedIPReservations{ @@ -441,7 +446,7 @@ var _ = Describe("IPReconciler", func() { It("errors when attempting to clean up the IP address", func() { reconciledIPs, err := ipReconciler.ReconcileIPPools(context.TODO()) - Expect(err).To(MatchError(fmt.Sprintf("did not find reserved IP for container %s", reservationPodRef))) + Expect(err).To(MatchError(fmt.Sprintf("did not find reserved IP for container %s", reservationContainerID))) Expect(reconciledIPs).To(BeEmpty()) }) }) @@ -547,11 +552,12 @@ func generateIPPool(cidr string, podRefs ...string) v1alpha1.IPPool { } } -func generateIPReservation(ip string, podRef string) []types.IPReservation { +func generateIPReservation(ip string, podRef, containerID string) []types.IPReservation { return []types.IPReservation{ { - IP: net.ParseIP(ip), - PodRef: podRef, + IP: net.ParseIP(ip), + PodRef: podRef, + ContainerID: containerID, }, } } diff --git a/pkg/reconciler/iploop.go b/pkg/reconciler/iploop.go index cc2b8fd65..32c04db1b 100644 --- a/pkg/reconciler/iploop.go +++ b/pkg/reconciler/iploop.go @@ -175,10 +175,11 @@ func composePodRef(pod v1.Pod) string { } func (rl ReconcileLooper) ReconcileIPPools(ctx context.Context) ([]net.IP, error) { - matchByPodRef := func(reservations []types.IPReservation, podRef string) int { + matchByContainerID := func(reservations []types.IPReservation, containerID string) int { foundidx := -1 + fmt.Printf("!bang ------------- %+v", reservations) for idx, v := range reservations { - if v.PodRef == podRef { + if v.ContainerID == containerID { return idx } } @@ -189,10 +190,10 @@ func (rl ReconcileLooper) ReconcileIPPools(ctx context.Context) ([]net.IP, error var totalCleanedUpIps []net.IP for _, orphanedIP := range rl.orphanedIPs { currentIPReservations := orphanedIP.Pool.Allocations() - podRefsToDeallocate := findOutPodRefsToDeallocateIPsFrom(orphanedIP) + containerIDsToDeallocate := findOutContainerIDsToDeallocateIPsFrom(orphanedIP) var deallocatedIP net.IP - for _, podRef := range podRefsToDeallocate { - currentIPReservations, deallocatedIP, err = allocate.IterateForDeallocation(currentIPReservations, podRef, matchByPodRef) + for _, containerID := range containerIDsToDeallocate { + currentIPReservations, deallocatedIP, err = allocate.IterateForDeallocation(currentIPReservations, containerID, matchByContainerID) if err != nil { return nil, err } @@ -256,10 +257,10 @@ func (rl ReconcileLooper) ReconcileOverlappingIPAddresses(ctx context.Context) e return nil } -func findOutPodRefsToDeallocateIPsFrom(orphanedIP OrphanedIPReservations) []string { - var podRefsToDeallocate []string +func findOutContainerIDsToDeallocateIPsFrom(orphanedIP OrphanedIPReservations) []string { + var containerIDsToDeallocate []string for _, orphanedAllocation := range orphanedIP.Allocations { - podRefsToDeallocate = append(podRefsToDeallocate, orphanedAllocation.PodRef) + containerIDsToDeallocate = append(containerIDsToDeallocate, orphanedAllocation.ContainerID) } - return podRefsToDeallocate + return containerIDsToDeallocate } From 3f2f19cbad9e872b54992a39949822a6fc4d013e Mon Sep 17 00:00:00 2001 From: dougbtv Date: Wed, 20 Dec 2023 14:52:09 -0500 Subject: [PATCH 2/3] [comments] Just updates comments to show possible problematic areas --- pkg/reconciler/iploop.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/pkg/reconciler/iploop.go b/pkg/reconciler/iploop.go index 32c04db1b..027ab6e84 100644 --- a/pkg/reconciler/iploop.go +++ b/pkg/reconciler/iploop.go @@ -189,10 +189,12 @@ func (rl ReconcileLooper) ReconcileIPPools(ctx context.Context) ([]net.IP, error var err error var totalCleanedUpIps []net.IP for _, orphanedIP := range rl.orphanedIPs { + // !bang: Reportedly: This the order returned from the below line is not fixed. currentIPReservations := orphanedIP.Pool.Allocations() containerIDsToDeallocate := findOutContainerIDsToDeallocateIPsFrom(orphanedIP) var deallocatedIP net.IP for _, containerID := range containerIDsToDeallocate { + // !bang: This means it may cause the in-use pod ip to be wrongly claimed currentIPReservations, deallocatedIP, err = allocate.IterateForDeallocation(currentIPReservations, containerID, matchByContainerID) if err != nil { return nil, err From 6f0bcca54ad0e89e3d440c7672442cbf929c80ed Mon Sep 17 00:00:00 2001 From: dougbtv Date: Wed, 20 Dec 2023 15:25:37 -0500 Subject: [PATCH 3/3] [increment] appears to be passing tests regularly... --- pkg/reconciler/ip_test.go | 12 ++++++++++-- pkg/reconciler/iploop.go | 1 - 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/pkg/reconciler/ip_test.go b/pkg/reconciler/ip_test.go index c22e5e1dd..cfb79215a 100644 --- a/pkg/reconciler/ip_test.go +++ b/pkg/reconciler/ip_test.go @@ -8,6 +8,9 @@ import ( "strings" "testing" + "math/rand" + "strconv" + . "github.com/onsi/ginkgo" . "github.com/onsi/gomega" @@ -150,6 +153,7 @@ var _ = Describe("Whereabouts IP reconciler", func() { Expect(deletedIPAddrs).To(Equal([]net.IP{net.ParseIP("10.10.10.1")})) }) + // !bang this can also be a problem area... It("the IPPool should have only the IP reservation of the live pod", func() { deletedIPAddrs, err := reconcileLooper.ReconcileIPPools(context.TODO()) Expect(err).NotTo(HaveOccurred()) @@ -163,7 +167,10 @@ var _ = Describe("Whereabouts IP reconciler", func() { PodRef: fmt.Sprintf("%s/%s", namespace, pods[livePodIndex].Name), }, } - Expect(poolAfterCleanup.Spec.Allocations).To(Equal(remainingAllocation)) + + for key, val := range poolAfterCleanup.Spec.Allocations { + Expect(val.PodRef).To(Equal(remainingAllocation[key].PodRef), "Mismatch at key: "+key) + } }) }) }) @@ -457,7 +464,8 @@ func generateIPPoolSpec(ipRange string, namespace string, poolName string, podNa allocations := map[string]v1alpha1.IPAllocation{} for i, podName := range podNames { allocations[fmt.Sprintf("%d", i+1)] = v1alpha1.IPAllocation{ - PodRef: fmt.Sprintf("%s/%s", namespace, podName), + PodRef: fmt.Sprintf("%s/%s", namespace, podName), + ContainerID: strconv.Itoa(rand.Intn(1000)), } } return &v1alpha1.IPPool{ diff --git a/pkg/reconciler/iploop.go b/pkg/reconciler/iploop.go index 027ab6e84..2e807d377 100644 --- a/pkg/reconciler/iploop.go +++ b/pkg/reconciler/iploop.go @@ -177,7 +177,6 @@ func composePodRef(pod v1.Pod) string { func (rl ReconcileLooper) ReconcileIPPools(ctx context.Context) ([]net.IP, error) { matchByContainerID := func(reservations []types.IPReservation, containerID string) int { foundidx := -1 - fmt.Printf("!bang ------------- %+v", reservations) for idx, v := range reservations { if v.ContainerID == containerID { return idx