From efb8800eaea638ebe84b8d4d739a73b163baa62e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Philipp=20Gill=C3=A9?= Date: Mon, 1 Jan 2024 19:04:46 +0100 Subject: [PATCH] Improve concurrency when adding documents to collection --- collection.go | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/collection.go b/collection.go index 114026d..60884b2 100644 --- a/collection.go +++ b/collection.go @@ -70,10 +70,11 @@ func (c *Collection) add(ctx context.Context, ids []string, documents []string, } ctx, cancel := context.WithCancelCause(ctx) + defer cancel(nil) var wg sync.WaitGroup var globalErr error - var globalErrLock sync.RWMutex + var globalErrLock sync.Mutex semaphore := make(chan struct{}, concurrency) for i, document := range documents { var embedding []float32 @@ -90,13 +91,9 @@ func (c *Collection) add(ctx context.Context, ids []string, documents []string, defer wg.Done() // Don't even start if we already have an error - globalErrLock.RLock() - // We don't defer the unlock because we want to unlock much earlier. - if globalErr != nil { - globalErrLock.RUnlock() + if ctx.Err() != nil { return } - globalErrLock.RUnlock() // Wait here while $concurrency other goroutines are creating documents. semaphore <- struct{}{}