llmongodb/counter.go

145 lines
2.2 KiB
Go
Raw Normal View History

2015-11-25 09:05:45 +01:00
// counter
package main
import (
"sync"
"time"
2015-11-25 09:05:45 +01:00
)
2016-10-05 11:55:50 +02:00
// Counter structure
2015-11-25 09:05:45 +01:00
type Counter struct {
mu sync.Mutex
user int
log int
rem int
err int
dup int
time time.Duration
2015-11-25 09:05:45 +01:00
wg []int
}
2016-10-05 11:55:50 +02:00
// NewCounter iniitialized Counter structure
2015-11-25 09:05:45 +01:00
func NewCounter() *Counter {
return &Counter{
user: 0,
log: 0,
err: 0,
rem: 0,
dup: 0,
time: 0,
2015-11-25 09:05:45 +01:00
wg: make([]int, opts.Concurrent),
}
}
2016-10-05 11:55:50 +02:00
// AddUser increment number of users managed
2015-11-25 09:05:45 +01:00
func (c *Counter) AddUser() {
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
c.user++
}
2016-10-05 11:55:50 +02:00
// AddDuplicate increment number of duplicates log
2015-11-25 09:05:45 +01:00
func (c *Counter) AddDuplicate() {
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
c.dup++
}
2016-10-05 11:55:50 +02:00
// AddLog increment number of log's rows managed
2015-11-25 09:05:45 +01:00
func (c *Counter) AddLog(add int) {
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
c.log += add
}
2016-10-05 11:55:50 +02:00
//AddRem increment removed logs row
2015-11-25 09:05:45 +01:00
func (c *Counter) AddRem(add int) {
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
c.rem += add
}
2016-10-05 11:55:50 +02:00
// AddWG ...
2015-11-25 09:05:45 +01:00
func (c *Counter) AddWG(id int) {
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
c.wg[id]++
}
2016-10-05 11:55:50 +02:00
// AddErr ...
2015-11-25 09:05:45 +01:00
func (c *Counter) AddErr() {
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
c.err++
}
2016-10-05 11:55:50 +02:00
// DelWG ...
func (c *Counter) DelWG(id int) {
2015-11-25 09:05:45 +01:00
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
c.wg[id]--
}
2016-10-05 11:55:50 +02:00
// GetUser return total users
func (c *Counter) GetUser() (ret int) {
2015-11-25 09:05:45 +01:00
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
ret = c.user
return
}
2016-10-05 11:55:50 +02:00
// GetDup return total duplicated logins
func (c *Counter) GetDup() (ret int) {
2015-11-25 09:05:45 +01:00
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
ret = c.dup
return
}
2016-10-05 11:55:50 +02:00
// GetLog return total log's rows
func (c *Counter) GetLog() (ret int) {
2015-11-25 09:05:45 +01:00
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
ret = c.log
return
}
2016-10-05 11:55:50 +02:00
// GetErr return total errors
func (c *Counter) GetErr() (ret int) {
2015-11-25 09:05:45 +01:00
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
ret = c.err
return
}
2016-10-05 11:55:50 +02:00
// GetRem return total removed log's rows
func (c *Counter) GetRem() (ret int) {
2015-11-25 09:05:45 +01:00
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
ret = c.rem
return
}
2016-10-05 11:55:50 +02:00
// GetWG ...
func (c *Counter) GetWG(id int) (ret int) {
2015-11-25 09:05:45 +01:00
c.mu.Lock()
defer c.mu.Unlock()
2015-11-25 09:05:45 +01:00
ret = c.wg[id]
return
}
2016-10-05 11:55:50 +02:00
// GetTime ...
func (c *Counter) GetTime() (ret float64) {
c.mu.Lock()
defer c.mu.Unlock()
ret = c.time.Seconds()
return
}
2016-10-05 11:55:50 +02:00
// SetTime ...
func (c *Counter) SetTime(t time.Duration) {
c.mu.Lock()
defer c.mu.Unlock()
c.time = t
}