2015-05-13 02:35:16 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"runtime"
|
2015-05-13 20:54:54 +02:00
|
|
|
"sync"
|
2015-05-13 02:35:16 +02:00
|
|
|
"time"
|
2015-05-14 18:16:00 +02:00
|
|
|
|
|
|
|
"github.com/manucorporat/stats"
|
2015-05-13 02:35:16 +02:00
|
|
|
)
|
|
|
|
|
2017-06-15 10:14:25 +08:00
|
|
|
var (
|
|
|
|
ips = stats.New()
|
|
|
|
messages = stats.New()
|
|
|
|
users = stats.New()
|
|
|
|
mutexStats sync.RWMutex
|
|
|
|
savedStats map[string]uint64
|
|
|
|
)
|
2015-05-13 20:54:54 +02:00
|
|
|
|
|
|
|
func statsWorker() {
|
|
|
|
c := time.Tick(1 * time.Second)
|
2016-04-15 01:16:46 +02:00
|
|
|
var lastMallocs uint64
|
|
|
|
var lastFrees uint64
|
|
|
|
for range c {
|
2015-05-13 20:54:54 +02:00
|
|
|
var stats runtime.MemStats
|
|
|
|
runtime.ReadMemStats(&stats)
|
2015-05-13 02:35:16 +02:00
|
|
|
|
2015-05-13 20:54:54 +02:00
|
|
|
mutexStats.Lock()
|
|
|
|
savedStats = map[string]uint64{
|
2015-05-14 18:16:00 +02:00
|
|
|
"timestamp": uint64(time.Now().Unix()),
|
|
|
|
"HeapInuse": stats.HeapInuse,
|
|
|
|
"StackInuse": stats.StackInuse,
|
2017-11-29 04:50:14 +02:00
|
|
|
"Mallocs": stats.Mallocs - lastMallocs,
|
|
|
|
"Frees": stats.Frees - lastFrees,
|
2015-05-14 18:16:00 +02:00
|
|
|
"Inbound": uint64(messages.Get("inbound")),
|
|
|
|
"Outbound": uint64(messages.Get("outbound")),
|
|
|
|
"Connected": connectedUsers(),
|
2015-05-13 20:54:54 +02:00
|
|
|
}
|
2015-05-14 18:16:00 +02:00
|
|
|
lastMallocs = stats.Mallocs
|
|
|
|
lastFrees = stats.Frees
|
2015-05-14 17:01:02 +02:00
|
|
|
messages.Reset()
|
2015-05-13 20:54:54 +02:00
|
|
|
mutexStats.Unlock()
|
2015-05-13 02:35:16 +02:00
|
|
|
}
|
|
|
|
}
|
2015-05-13 20:54:54 +02:00
|
|
|
|
2015-05-14 18:16:00 +02:00
|
|
|
func connectedUsers() uint64 {
|
|
|
|
connected := users.Get("connected") - users.Get("disconnected")
|
|
|
|
if connected < 0 {
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
return uint64(connected)
|
|
|
|
}
|
|
|
|
|
2015-05-13 20:54:54 +02:00
|
|
|
func Stats() map[string]uint64 {
|
|
|
|
mutexStats.RLock()
|
|
|
|
defer mutexStats.RUnlock()
|
|
|
|
|
|
|
|
return savedStats
|
|
|
|
}
|