go-zero/example/rpc/client/lb/main.go

58 lines
1.0 KiB
Go
Raw Normal View History

2020-08-06 20:55:38 +08:00
package main
import (
"context"
2020-08-18 18:36:44 +08:00
"flag"
2020-08-06 20:55:38 +08:00
"fmt"
2020-08-18 18:36:44 +08:00
"log"
2020-08-06 20:55:38 +08:00
"time"
2020-08-08 16:40:10 +08:00
"github.com/tal-tech/go-zero/core/discov"
"github.com/tal-tech/go-zero/example/rpc/remote/unary"
"github.com/tal-tech/go-zero/rpcx"
2020-08-06 20:55:38 +08:00
)
2020-08-18 18:36:44 +08:00
var lb = flag.String("t", "direct", "the load balancer type")
2020-08-06 20:55:38 +08:00
func main() {
2020-08-18 18:36:44 +08:00
flag.Parse()
var cli rpcx.Client
switch *lb {
case "direct":
cli = rpcx.MustNewClient(rpcx.RpcClientConf{
Endpoints: []string{
"localhost:3456",
"localhost:3457",
},
})
case "discov":
cli = rpcx.MustNewClient(rpcx.RpcClientConf{
Etcd: discov.EtcdConf{
Hosts: []string{"localhost:2379"},
Key: "rpcx",
},
})
default:
log.Fatal("bad load balancing type")
}
2020-08-06 20:55:38 +08:00
greet := unary.NewGreeterClient(cli.Conn())
ticker := time.NewTicker(time.Second)
defer ticker.Stop()
for {
select {
case <-ticker.C:
resp, err := greet.Greet(context.Background(), &unary.Request{
Name: "kevin",
})
if err != nil {
fmt.Println("X", err.Error())
} else {
fmt.Println("=>", resp.Greet)
}
}
}
}