Create & Init Project...

This commit is contained in:
2019-04-22 18:49:16 +08:00
commit fc4fa37393
25440 changed files with 4054998 additions and 0 deletions

View File

@@ -0,0 +1,41 @@
package(default_visibility = ["//visibility:public"])
load(
"@io_bazel_rules_go//go:def.bzl",
"go_binary",
"go_library",
)
go_binary(
name = "client",
embed = [":go_default_library"],
tags = ["automanaged"],
)
go_library(
name = "go_default_library",
srcs = ["greeter_client.go"],
importpath = "go-common/library/net/rpc/warden/benchmark/helloworld/client",
tags = ["automanaged"],
visibility = ["//visibility:public"],
deps = [
"//library/net/netutil/breaker:go_default_library",
"//library/net/rpc/warden:go_default_library",
"//library/net/rpc/warden/proto/testproto:go_default_library",
"//library/time:go_default_library",
],
)
filegroup(
name = "package-srcs",
srcs = glob(["**"]),
tags = ["automanaged"],
visibility = ["//visibility:private"],
)
filegroup(
name = "all-srcs",
srcs = [":package-srcs"],
tags = ["automanaged"],
visibility = ["//visibility:public"],
)

View File

@@ -0,0 +1,85 @@
package main
import (
"context"
"flag"
"fmt"
"math/rand"
"sync"
"sync/atomic"
"time"
"go-common/library/net/netutil/breaker"
"go-common/library/net/rpc/warden"
pb "go-common/library/net/rpc/warden/proto/testproto"
xtime "go-common/library/time"
)
var (
ccf = &warden.ClientConfig{
Dial: xtime.Duration(time.Second * 10),
Timeout: xtime.Duration(time.Second * 10),
Breaker: &breaker.Config{
Window: xtime.Duration(3 * time.Second),
Sleep: xtime.Duration(3 * time.Second),
Bucket: 10,
Ratio: 0.3,
Request: 20,
},
}
cli pb.GreeterClient
wg sync.WaitGroup
reqSize int
concurrency int
request int
all int64
)
func init() {
flag.IntVar(&reqSize, "s", 10, "request size")
flag.IntVar(&concurrency, "c", 10, "concurrency")
flag.IntVar(&request, "r", 1000, "request per routine")
}
func main() {
flag.Parse()
name := randSeq(reqSize)
cli = newClient()
for i := 0; i < concurrency; i++ {
wg.Add(1)
go sayHello(&pb.HelloRequest{Name: name})
}
wg.Wait()
fmt.Printf("per request cost %v\n", all/int64(request*concurrency))
}
func sayHello(in *pb.HelloRequest) {
defer wg.Done()
now := time.Now()
for i := 0; i < request; i++ {
cli.SayHello(context.TODO(), in)
}
delta := time.Since(now)
atomic.AddInt64(&all, int64(delta/time.Millisecond))
}
var letters = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")
func randSeq(n int) string {
b := make([]rune, n)
for i := range b {
b[i] = letters[rand.Intn(len(letters))]
}
return string(b)
}
func newClient() (cli pb.GreeterClient) {
client := warden.NewClient(ccf)
conn, err := client.Dial(context.TODO(), "127.0.0.1:9999")
if err != nil {
return
}
cli = pb.NewGreeterClient(conn)
return
}