63 lines
1.5 KiB
Go
63 lines
1.5 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/config"
|
|
"github.com/anytypeio/go-anytype-infrastructure-experiments/syncproto"
|
|
"google.golang.org/grpc"
|
|
"google.golang.org/grpc/credentials"
|
|
"google.golang.org/grpc/credentials/insecure"
|
|
"log"
|
|
"time"
|
|
)
|
|
|
|
// req/rep 1000000 req for 1m56.663998462s (8571 per sec)
|
|
// stream 1000000 req for 1m25.54958362s (11689 per sec)
|
|
|
|
func main() {
|
|
|
|
conf, err := config.NewFromFile("etc/config.yml")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
var opts []grpc.DialOption
|
|
if conf.GrpcServer.TLS {
|
|
creds, err := credentials.NewClientTLSFromFile(conf.GrpcServer.TLSCertFile, "127.0.0.1")
|
|
if err != nil {
|
|
log.Fatalf("Failed to create TLS credentials %v", err)
|
|
}
|
|
opts = append(opts, grpc.WithTransportCredentials(creds))
|
|
} else {
|
|
opts = append(opts, grpc.WithTransportCredentials(insecure.NewCredentials()))
|
|
}
|
|
|
|
conn, err := grpc.Dial(conf.GrpcServer.ListenAddrs[0], opts...)
|
|
if err != nil {
|
|
log.Fatalf("fail to dial: %v", err)
|
|
}
|
|
defer conn.Close()
|
|
client := syncproto.NewAnytypeSyncClient(conn)
|
|
stream, err := client.Ping(context.TODO())
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
st := time.Now()
|
|
n := 1000000
|
|
for i := 0; i < n; i++ {
|
|
if err = stream.Send(&syncproto.PingRequest{
|
|
Seq: int64(i),
|
|
}); err != nil {
|
|
panic(err)
|
|
}
|
|
_, err := stream.Recv()
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
}
|
|
dur := time.Since(st)
|
|
fmt.Printf("%d req for %v (%d per sec)\n", n, dur, int(float64(n)/dur.Seconds()))
|
|
|
|
}
|