mirror of
https://github.com/Luzifer/elb-instance-status.git
synced 2025-01-10 03:31:56 +00:00
Compare commits
2 commits
879faa0a36
...
84df5e9f1a
Author | SHA1 | Date | |
---|---|---|---|
84df5e9f1a | |||
99391db514 |
2 changed files with 20 additions and 2 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
# 1.1.2 / 2024-04-20
|
||||||
|
|
||||||
|
* Fix: Cleanup context after checks have run
|
||||||
|
|
||||||
# 1.1.1 / 2024-04-19
|
# 1.1.1 / 2024-04-19
|
||||||
|
|
||||||
* Update dependencies
|
* Update dependencies
|
||||||
|
|
18
checks.go
18
checks.go
|
@ -8,6 +8,7 @@ import (
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
|
@ -143,9 +144,22 @@ func loadChecks() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func spawnChecks() {
|
func spawnChecks() {
|
||||||
ctx, _ := context.WithTimeout(context.Background(), cfg.CheckInterval-time.Second)
|
var wg sync.WaitGroup
|
||||||
|
|
||||||
|
ctx, cancel := context.WithTimeout(context.Background(), cfg.CheckInterval-time.Second)
|
||||||
|
|
||||||
|
wg.Add(len(checks))
|
||||||
|
go func() {
|
||||||
|
// Do not block the execution function but cleanup the context after
|
||||||
|
// all checks are done (or cancelled)
|
||||||
|
wg.Wait()
|
||||||
|
cancel()
|
||||||
|
}()
|
||||||
|
|
||||||
for id := range checks {
|
for id := range checks {
|
||||||
go executeAndRegisterCheck(ctx, id)
|
go func(ctx context.Context, id string) {
|
||||||
|
defer wg.Done()
|
||||||
|
executeAndRegisterCheck(ctx, id)
|
||||||
|
}(ctx, id)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue