You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
91 lines
1.9 KiB
Go
91 lines
1.9 KiB
Go
/*
|
|
Command rqbench is a rqlite load test utility.
|
|
*/
|
|
|
|
package main
|
|
|
|
import (
|
|
"flag"
|
|
"fmt"
|
|
"time"
|
|
|
|
"os"
|
|
)
|
|
|
|
var addr string
|
|
var numReqs int
|
|
var batchSz int
|
|
var modPrint int
|
|
var tx bool
|
|
var tp string
|
|
|
|
const name = `rqbench`
|
|
const desc = `rqbench is a simple load testing utility for rqlite.`
|
|
|
|
func init() {
|
|
flag.StringVar(&addr, "a", "localhost:4001", "Node address")
|
|
flag.IntVar(&numReqs, "n", 100, "Number of requests")
|
|
flag.IntVar(&batchSz, "b", 1, "Statements per request")
|
|
flag.IntVar(&modPrint, "m", 0, "Print progress every m requests")
|
|
flag.BoolVar(&tx, "x", false, "Use explicit transaction per request")
|
|
flag.StringVar(&tp, "t", "http", "Transport to use")
|
|
flag.Usage = func() {
|
|
fmt.Fprintf(os.Stderr, "\n%s\n\n", desc)
|
|
fmt.Fprintf(os.Stderr, "Usage: %s [arguments] <SQL statement>\n", name)
|
|
flag.PrintDefaults()
|
|
}
|
|
}
|
|
|
|
func main() {
|
|
flag.Parse()
|
|
|
|
// Ensure the SQL statement is set
|
|
if flag.NArg() == 0 {
|
|
flag.Usage()
|
|
os.Exit(1)
|
|
}
|
|
stmt := flag.Args()[0]
|
|
|
|
if tp != "http" {
|
|
fmt.Fprintf(os.Stderr, "not a valid transport: %s\n", tp)
|
|
}
|
|
|
|
tester := NewHTTPTester(addr)
|
|
if err := tester.Prepare(stmt, batchSz, tx); err != nil {
|
|
fmt.Println("failed to prepare test:", err.Error())
|
|
os.Exit(1)
|
|
}
|
|
|
|
d, err := run(tester, numReqs)
|
|
if err != nil {
|
|
fmt.Println("failed to run test:", err.Error())
|
|
os.Exit(1)
|
|
}
|
|
fmt.Println("Total duration:", d)
|
|
fmt.Printf("Requests/sec: %.2f\n", float64((numReqs))/d.Seconds())
|
|
fmt.Printf("Statements/sec: %.2f\n", float64((numReqs*batchSz))/d.Seconds())
|
|
}
|
|
|
|
type Tester interface {
|
|
Prepare(stmt string, bSz int, tx bool) error
|
|
Once() (time.Duration, error)
|
|
}
|
|
|
|
func run(t Tester, n int) (time.Duration, error) {
|
|
var dur time.Duration
|
|
|
|
for i := 0; i < n; i++ {
|
|
d, err := t.Once()
|
|
if err != nil {
|
|
return 0, err
|
|
} else {
|
|
dur += d
|
|
}
|
|
|
|
if modPrint != 0 && i != 0 && i%modPrint == 0 {
|
|
fmt.Printf("%d requests completed in %s\n", i, d)
|
|
}
|
|
}
|
|
return dur, nil
|
|
}
|