Files
old-vegeta/main.go

92 lines
2.1 KiB
Go
Raw Normal View History

2013-08-13 13:47:01 +02:00
package main
import (
"flag"
"log"
"math"
"math/rand"
"net/http"
2013-08-13 18:51:00 +02:00
"os"
2013-08-13 13:47:01 +02:00
"time"
)
func main() {
var (
// Flags
2013-08-13 18:51:00 +02:00
rate = flag.Uint("rate", 50, "Requests per second")
targetsf = flag.String("targets", "targets.txt", "Targets file")
ordering = flag.String("ordering", "random", "Attack ordering [sequential, random]")
duration = flag.Duration("duration", 10*time.Second, "Duration of the test")
reporter = flag.String("reporter", "text", "Reporter to use [text]")
2013-08-13 13:47:01 +02:00
)
flag.Parse()
2013-08-13 18:51:00 +02:00
if flag.NFlag() == 0 {
flag.Usage()
return
}
// Validate rate argument
if *rate == 0 {
log.Fatal("rate can't be zero")
2013-08-13 13:47:01 +02:00
}
// Magic formula that assumes each client can
2013-08-13 18:51:00 +02:00
// sustain 200 RPS under normal circumstances
clients := make([]*Client, int(math.Ceil(float64(*rate)/200.0)))
ratePerClient := *rate / uint(len(clients))
for i := 0; i < len(clients); i++ {
2013-08-13 18:51:00 +02:00
clients[i] = NewClient(ratePerClient)
}
2013-08-13 13:47:01 +02:00
2013-08-13 18:51:00 +02:00
// Parse targets file
targets, err := NewTargetsFromFile(*targetsf)
if err != nil {
2013-08-13 13:47:01 +02:00
log.Fatal(err)
}
2013-08-13 18:51:00 +02:00
// Parse ordering argument
random := false
2013-08-13 18:51:00 +02:00
if *ordering == "random" {
2013-08-13 13:47:01 +02:00
rand.Seed(time.Now().UnixNano())
random = true
2013-08-13 18:51:00 +02:00
} else if *ordering != "sequential" {
log.Fatalf("Unknown ordering %s", *ordering)
2013-08-13 13:47:01 +02:00
}
2013-08-13 18:51:00 +02:00
// Parse duration
if *duration == 0 {
log.Fatal("Duration provided is invalid")
2013-08-13 13:47:01 +02:00
}
2013-08-13 18:51:00 +02:00
hits := make(chan *http.Request, *rate*uint((*duration).Seconds()))
for i, idxs := 0, targets.Iter(random); i < cap(hits); i++ {
hits <- targets[idxs[i%len(idxs)]]
}
// Attack!
responses := make(chan *Response, cap(hits))
for _, client := range clients {
2013-08-13 18:51:00 +02:00
go client.Drill(hits, responses)
2013-08-13 13:47:01 +02:00
}
2013-08-13 18:51:00 +02:00
log.Printf("Vegeta is attacking ")
log.Printf("%d targets in %s order for %s with %d clients.\n", len(targets), *ordering, duration, len(clients))
var rep Reporter
switch *reporter {
case "text":
rep = NewTextReporter(len(responses))
default:
log.Println("reporter provided is not supported. using text")
rep = NewTextReporter(len(responses))
}
// Wait for all requests to finish
for i := 0; i < cap(responses); i++ {
rep.Add(<-responses)
}
close(hits)
close(responses)
if rep.Report(os.Stdout) != nil {
log.Fatal("Failed to report!")
2013-08-13 13:47:01 +02:00
}
}