mirror of
https://github.com/octoleo/syncthing.git
synced 2025-02-08 23:08:27 +00:00
Add performance stats collection
This commit is contained in:
parent
3b34895ae6
commit
2aa4340551
3
.gitignore
vendored
3
.gitignore
vendored
@ -8,3 +8,6 @@ discosrv
|
|||||||
.jshintrc
|
.jshintrc
|
||||||
coverage.out
|
coverage.out
|
||||||
files/pidx
|
files/pidx
|
||||||
|
discosrv.exe
|
||||||
|
bin
|
||||||
|
perfstats*.csv
|
||||||
|
45
cmd/syncthing/perfstats.go
Normal file
45
cmd/syncthing/perfstats.go
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
// +build perfstats
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
"runtime"
|
||||||
|
"syscall"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
go savePerfStats(fmt.Sprintf("perfstats-%d.csv", syscall.Getpid()))
|
||||||
|
}
|
||||||
|
|
||||||
|
func savePerfStats(file string) {
|
||||||
|
fd, err := os.Create(file)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var prevUsage int64
|
||||||
|
var prevTime int64
|
||||||
|
var rusage syscall.Rusage
|
||||||
|
var memstats runtime.MemStats
|
||||||
|
|
||||||
|
t0 := time.Now()
|
||||||
|
for t := range time.NewTicker(250 * time.Millisecond).C {
|
||||||
|
syscall.Getrusage(syscall.RUSAGE_SELF, &rusage)
|
||||||
|
curTime := time.Now().UnixNano()
|
||||||
|
timeDiff := curTime - prevTime
|
||||||
|
curUsage := rusage.Utime.Nano() + rusage.Stime.Nano()
|
||||||
|
usageDiff := curUsage - prevUsage
|
||||||
|
cpuUsagePercent := 100 * float64(usageDiff) / float64(timeDiff)
|
||||||
|
prevTime = curTime
|
||||||
|
prevUsage = curUsage
|
||||||
|
|
||||||
|
runtime.ReadMemStats(&memstats)
|
||||||
|
|
||||||
|
startms := int(t.Sub(t0).Seconds() * 1000)
|
||||||
|
|
||||||
|
fmt.Fprintf(fd, "%d\t%f\t%d\t%d\n", startms, cpuUsagePercent, memstats.Alloc, memstats.Sys)
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user