honor canceled context and do not leak on mergeChannels (#15034)

mergeEntryChannels has the potential to perpetually
wait on the results channel, context might be closed
and we did not honor the caller context canceling.
This commit is contained in:
Harshavardhana 2022-06-03 05:59:02 -07:00 committed by GitHub
parent 20a753e2e5
commit c3e1da8e04
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 10 additions and 5 deletions

View File

@ -695,8 +695,12 @@ func mergeEntryChannels(ctx context.Context, in []chan metaCacheEntry, out chan<
} }
} }
if best.name > last { if best.name > last {
out <- *best select {
last = best.name case <-ctxDone:
return ctx.Err()
case out <- *best:
last = best.name
}
} else if serverDebugLog { } else if serverDebugLog {
console.Debugln("mergeEntryChannels: discarding duplicate", best.name, "<=", last) console.Debugln("mergeEntryChannels: discarding duplicate", best.name, "<=", last)
} }

View File

@ -554,11 +554,11 @@ func (z *erasureServerPools) listMerged(ctx context.Context, o listPathOptions,
for _, pool := range z.serverPools { for _, pool := range z.serverPools {
for _, set := range pool.sets { for _, set := range pool.sets {
wg.Add(1) wg.Add(1)
results := make(chan metaCacheEntry, 100) innerResults := make(chan metaCacheEntry, 100)
inputs = append(inputs, results) inputs = append(inputs, innerResults)
go func(i int, set *erasureObjects) { go func(i int, set *erasureObjects) {
defer wg.Done() defer wg.Done()
err := set.listPath(listCtx, o, results) err := set.listPath(listCtx, o, innerResults)
mu.Lock() mu.Lock()
defer mu.Unlock() defer mu.Unlock()
if err == nil { if err == nil {
@ -609,6 +609,7 @@ func (z *erasureServerPools) listMerged(ctx context.Context, o listPathOptions,
if err != nil { if err != nil {
return err return err
} }
if contextCanceled(ctx) { if contextCanceled(ctx) {
return ctx.Err() return ctx.Err()
} }