From af1d70b0265baf557df3c24f19958f0a682a0c03 Mon Sep 17 00:00:00 2001 From: Mitchell Hashimoto Date: Fri, 20 Apr 2018 10:43:50 -0700 Subject: [PATCH] agent/cache: don't every block on NotifyCh --- agent/cache/entry.go | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/agent/cache/entry.go b/agent/cache/entry.go index f651e64213..a1af4801c0 100644 --- a/agent/cache/entry.go +++ b/agent/cache/entry.go @@ -76,7 +76,7 @@ func (h *expiryHeap) Fix(entry *cacheEntryExpiry) { // is zero, it means the head-of-line didn't change while the value // changed. Notify to reset our expiry worker. if idx == 0 && entry.HeapIndex == 0 { - h.NotifyCh <- struct{}{} + h.notify() } } @@ -91,7 +91,7 @@ func (h *expiryHeap) Swap(i, j int) { // to re-update the timer we're waiting on for the soonest expiring // value. if i == 0 || j == 0 { - h.NotifyCh <- struct{}{} + h.notify() } } @@ -113,7 +113,7 @@ func (h *expiryHeap) Push(x interface{}) { // Swap won't be called; nothing to swap! We can call it right away // because all heap operations are within a lock. if len(h.Entries) == 0 { - h.NotifyCh <- struct{}{} + h.notify() } h.Entries = append(h.Entries, entry) @@ -126,3 +126,16 @@ func (h *expiryHeap) Pop() interface{} { h.Entries = old[0 : n-1] return x } + +func (h *expiryHeap) notify() { + select { + case h.NotifyCh <- struct{}{}: + // Good + + default: + // If the send would've blocked, we just ignore it. The reason this + // is safe is because NotifyCh should always be a buffered channel. + // If this blocks, it means that there is a pending message anyways + // so the receiver will restart regardless. + } +}