1
0
Fork 0
mirror of https://github.com/Luzifer/webcheck.git synced 2025-01-04 17:46:07 +00:00

Fix: Limit historical performance data

in order not to consume an endless amount of memory

Signed-off-by: Knut Ahlers <knut@ahlers.me>
This commit is contained in:
Knut Ahlers 2018-07-24 13:36:12 +02:00
parent 0a3219ce4a
commit 4bffea4f10
Signed by: luzifer
GPG key ID: DC2729FDD34BE99E
3 changed files with 64 additions and 6 deletions

1
.gitignore vendored
View file

@ -1 +1,2 @@
request-log
webcheck

18
main.go
View file

@ -19,7 +19,10 @@ import (
log "github.com/sirupsen/logrus"
)
const dateFormat = time.RFC1123
const (
dateFormat = time.RFC1123
numHistoricalDurations = 300
)
var (
cfg = struct {
@ -54,7 +57,7 @@ const (
type checkResult struct {
DumpFile string
Durations []time.Duration
Durations *ringDuration
Message string
Start time.Time
Status checkStatus
@ -64,8 +67,11 @@ type checkResult struct {
}
func newCheckResult(status checkStatus, message string, duration time.Duration) *checkResult {
r := newRingDuration(numHistoricalDurations)
r.SetNext(duration)
return &checkResult{
Durations: []time.Duration{duration},
Durations: r,
Message: message,
Start: time.Now(),
Status: status,
@ -76,7 +82,7 @@ func (c *checkResult) AddDuration(d time.Duration) {
c.lock.Lock()
defer c.lock.Unlock()
c.Durations = append(c.Durations, d)
c.Durations.SetNext(d)
}
func (c *checkResult) DurationStats() string {
@ -84,7 +90,7 @@ func (c *checkResult) DurationStats() string {
defer c.lock.RUnlock()
var (
s = stats.LoadRawData(c.Durations)
s = stats.LoadRawData(c.Durations.GetAll())
min, avg, max float64
err error
)
@ -176,7 +182,7 @@ func main() {
lastResult.DumpFile = fn
}
} else {
lastResult.AddDuration(result.Durations[0])
lastResult.AddDuration(result.Durations.GetCurrent())
}
lastResult.Print()

51
ring.go Normal file
View file

@ -0,0 +1,51 @@
package main
import (
"sync"
"time"
)
type ringDuration struct {
store []time.Duration
current int
lock sync.RWMutex
}
func newRingDuration(maxLen int) *ringDuration {
return &ringDuration{
store: make([]time.Duration, 0, maxLen),
current: -1, // Initial value to start the ring with element 0
}
}
func (r *ringDuration) SetNext(i time.Duration) {
r.lock.Lock()
defer r.lock.Unlock()
next := r.current + 1
if next == cap(r.store) {
next = 0
}
if next == len(r.store) {
r.store = append(r.store, 0)
}
r.store[next] = i
r.current = next
}
func (r *ringDuration) GetAll() []time.Duration {
r.lock.RLock()
defer r.lock.RUnlock()
return r.store
}
func (r *ringDuration) GetCurrent() time.Duration {
r.lock.RLock()
defer r.lock.RUnlock()
return r.store[r.current]
}