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"
|
2020-09-18 11:41:52 +08:00
|
|
|
"github.com/tal-tech/go-zero/zrpc"
|
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()
|
|
|
|
|
2020-09-18 11:41:52 +08:00
|
|
|
var cli zrpc.Client
|
2020-08-18 18:36:44 +08:00
|
|
|
switch *lb {
|
|
|
|
case "direct":
|
2020-09-18 11:41:52 +08:00
|
|
|
cli = zrpc.MustNewClient(zrpc.RpcClientConf{
|
2020-08-18 18:36:44 +08:00
|
|
|
Endpoints: []string{
|
|
|
|
"localhost:3456",
|
|
|
|
"localhost:3457",
|
|
|
|
},
|
|
|
|
})
|
|
|
|
case "discov":
|
2020-09-18 11:41:52 +08:00
|
|
|
cli = zrpc.MustNewClient(zrpc.RpcClientConf{
|
2020-08-18 18:36:44 +08:00
|
|
|
Etcd: discov.EtcdConf{
|
|
|
|
Hosts: []string{"localhost:2379"},
|
2020-09-18 11:41:52 +08:00
|
|
|
Key: "zrpc",
|
2020-08-18 18:36:44 +08:00
|
|
|
},
|
|
|
|
})
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|