Merge pull request #83945 from barkbay/fix-83895
Fix memory and timer leak in work queue
This commit is contained in:
		| @@ -178,6 +178,9 @@ func (q *delayingType) waitingLoop() { | |||||||
| 	// Make a placeholder channel to use when there are no items in our list | 	// Make a placeholder channel to use when there are no items in our list | ||||||
| 	never := make(<-chan time.Time) | 	never := make(<-chan time.Time) | ||||||
|  |  | ||||||
|  | 	// Make a timer that expires when the item at the head of the waiting queue is ready | ||||||
|  | 	var nextReadyAtTimer clock.Timer | ||||||
|  |  | ||||||
| 	waitingForQueue := &waitForPriorityQueue{} | 	waitingForQueue := &waitForPriorityQueue{} | ||||||
| 	heap.Init(waitingForQueue) | 	heap.Init(waitingForQueue) | ||||||
|  |  | ||||||
| @@ -205,8 +208,12 @@ func (q *delayingType) waitingLoop() { | |||||||
| 		// Set up a wait for the first item's readyAt (if one exists) | 		// Set up a wait for the first item's readyAt (if one exists) | ||||||
| 		nextReadyAt := never | 		nextReadyAt := never | ||||||
| 		if waitingForQueue.Len() > 0 { | 		if waitingForQueue.Len() > 0 { | ||||||
|  | 			if nextReadyAtTimer != nil { | ||||||
|  | 				nextReadyAtTimer.Stop() | ||||||
|  | 			} | ||||||
| 			entry := waitingForQueue.Peek().(*waitFor) | 			entry := waitingForQueue.Peek().(*waitFor) | ||||||
| 			nextReadyAt = q.clock.After(entry.readyAt.Sub(now)) | 			nextReadyAtTimer = q.clock.NewTimer(entry.readyAt.Sub(now)) | ||||||
|  | 			nextReadyAt = nextReadyAtTimer.C() | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		select { | 		select { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot