mirror of
https://github.com/netbirdio/netbird.git
synced 2025-01-08 06:59:10 +01:00
2147bf75eb
Limit the peer connection initialization to 200 peers at the same time
49 lines
1.0 KiB
Go
49 lines
1.0 KiB
Go
package semaphoregroup
|
|
|
|
import (
|
|
"context"
|
|
"sync"
|
|
)
|
|
|
|
// SemaphoreGroup is a custom type that combines sync.WaitGroup and a semaphore.
|
|
type SemaphoreGroup struct {
|
|
waitGroup sync.WaitGroup
|
|
semaphore chan struct{}
|
|
}
|
|
|
|
// NewSemaphoreGroup creates a new SemaphoreGroup with the specified semaphore limit.
|
|
func NewSemaphoreGroup(limit int) *SemaphoreGroup {
|
|
return &SemaphoreGroup{
|
|
semaphore: make(chan struct{}, limit),
|
|
}
|
|
}
|
|
|
|
// Add increments the internal WaitGroup counter and acquires a semaphore slot.
|
|
func (sg *SemaphoreGroup) Add(ctx context.Context) {
|
|
sg.waitGroup.Add(1)
|
|
|
|
// Acquire semaphore slot
|
|
select {
|
|
case <-ctx.Done():
|
|
return
|
|
case sg.semaphore <- struct{}{}:
|
|
}
|
|
}
|
|
|
|
// Done decrements the internal WaitGroup counter and releases a semaphore slot.
|
|
func (sg *SemaphoreGroup) Done(ctx context.Context) {
|
|
sg.waitGroup.Done()
|
|
|
|
// Release semaphore slot
|
|
select {
|
|
case <-ctx.Done():
|
|
return
|
|
case <-sg.semaphore:
|
|
}
|
|
}
|
|
|
|
// Wait waits until the internal WaitGroup counter is zero.
|
|
func (sg *SemaphoreGroup) Wait() {
|
|
sg.waitGroup.Wait()
|
|
}
|