From 6b9e4f939ddd6c60ebeaf92cc83b184e24c2252c Mon Sep 17 00:00:00 2001 From: Nick Craig-Wood Date: Mon, 8 Feb 2021 11:59:01 +0000 Subject: [PATCH] union: fix crash when using epff policy - fixes #5000 Before this fix using the epff policy could double close a channel. The fix refactors the code to make that impossible and cancels any running queries when the first query is found. --- backend/union/policy/epff.go | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/backend/union/policy/epff.go b/backend/union/policy/epff.go index ea4527087..e984bf2fd 100644 --- a/backend/union/policy/epff.go +++ b/backend/union/policy/epff.go @@ -17,7 +17,9 @@ func init() { type EpFF struct{} func (p *EpFF) epff(ctx context.Context, upstreams []*upstream.Fs, filePath string) (*upstream.Fs, error) { - ch := make(chan *upstream.Fs) + ch := make(chan *upstream.Fs, len(upstreams)) + ctx, cancel := context.WithCancel(ctx) + defer cancel() for _, u := range upstreams { u := u // Closure go func() { @@ -30,16 +32,10 @@ func (p *EpFF) epff(ctx context.Context, upstreams []*upstream.Fs, filePath stri }() } var u *upstream.Fs - for i := 0; i < len(upstreams); i++ { + for range upstreams { u = <-ch if u != nil { - // close remaining goroutines - go func(num int) { - defer close(ch) - for i := 0; i < num; i++ { - <-ch - } - }(len(upstreams) - 1 - i) + break } } if u == nil {