2022-10-09 09:25:28 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
"time"
|
2022-10-18 23:46:47 +02:00
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
2022-10-09 09:25:28 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Benchmark to store benchmark state
|
|
|
|
type Benchmark struct {
|
|
|
|
duration time.Duration
|
|
|
|
connections int
|
|
|
|
databases []*Database
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewBenchmark connects to the database then creates a Benchmark struct
|
|
|
|
func NewBenchmark(connections int, duration time.Duration, driver string, dsn string, query string, reconnect bool) (*Benchmark, error) {
|
|
|
|
var databases []*Database
|
|
|
|
for i := 0; i < connections; i++ {
|
|
|
|
database, err := NewDatabase(driver, dsn, query, reconnect)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
databases = append(databases, database)
|
|
|
|
}
|
|
|
|
return &Benchmark{
|
|
|
|
duration: duration,
|
|
|
|
connections: connections,
|
|
|
|
databases: databases,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Run performs the benchmark by runing queries for a duration
|
|
|
|
func (b *Benchmark) Run() {
|
|
|
|
wg := new(sync.WaitGroup)
|
|
|
|
wg.Add(b.connections)
|
|
|
|
for _, database := range b.databases {
|
|
|
|
go database.Run(b.duration, wg)
|
|
|
|
}
|
|
|
|
wg.Wait()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Queries returns the number of executed queries during the benchmark
|
|
|
|
func (b *Benchmark) Queries() (queries float64) {
|
|
|
|
for _, database := range b.databases {
|
2022-10-18 23:46:47 +02:00
|
|
|
log.Debugf("Connection %s: Queries: %.f", database.ID, database.Queries())
|
2022-10-09 09:25:28 +02:00
|
|
|
queries = queries + database.Queries()
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueriesPerSecond returns the number of executed queries per second during the benchmark
|
|
|
|
func (b *Benchmark) QueriesPerSecond() float64 {
|
|
|
|
return b.Queries() / b.duration.Seconds()
|
|
|
|
}
|
2022-10-18 23:46:47 +02:00
|
|
|
|
|
|
|
// AverageQueryTime computes the average query execution time for all databases connections in the benchmark
|
|
|
|
func (b *Benchmark) AverageQueryTime() time.Duration {
|
|
|
|
var latencies time.Duration
|
|
|
|
for _, database := range b.databases {
|
|
|
|
log.Debugf("Connection %s: Latency: %s", database.ID, database.AverageQueryTime())
|
|
|
|
latencies = latencies + database.AverageQueryTime()
|
|
|
|
}
|
|
|
|
latency := int64(latencies) / int64(len(b.databases))
|
|
|
|
return time.Duration(latency)
|
|
|
|
}
|