You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
83 lines
2.1 KiB
83 lines
2.1 KiB
3 years ago
|
package main
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"log"
|
||
|
"time"
|
||
|
|
||
|
"github.com/go-kratos/kratos/contrib/registry/consul/v2"
|
||
|
"github.com/go-kratos/kratos/examples/helloworld/helloworld"
|
||
|
"github.com/go-kratos/kratos/v2/middleware/recovery"
|
||
|
"github.com/go-kratos/kratos/v2/selector/filter"
|
||
|
"github.com/go-kratos/kratos/v2/selector/p2c"
|
||
|
"github.com/go-kratos/kratos/v2/selector/wrr"
|
||
|
"github.com/go-kratos/kratos/v2/transport/grpc"
|
||
|
"github.com/go-kratos/kratos/v2/transport/http"
|
||
|
"github.com/hashicorp/consul/api"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
consulCli, err := api.NewClient(api.DefaultConfig())
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
r := consul.New(consulCli)
|
||
|
|
||
|
// new grpc client
|
||
|
conn, err := grpc.DialInsecure(
|
||
|
context.Background(),
|
||
|
grpc.WithEndpoint("discovery:///helloworld"),
|
||
|
grpc.WithDiscovery(r),
|
||
|
// 由于gRPC框架的限制只能使用全局balancer+filter的方式来实现selector
|
||
|
// 这里使用weighted round robin算法的balancer+静态version=1.0.0的Filter
|
||
|
grpc.WithBalancerName(wrr.Name),
|
||
|
grpc.WithSelectFilter(filter.Version("1.0.0")),
|
||
|
)
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
defer conn.Close()
|
||
|
gClient := helloworld.NewGreeterClient(conn)
|
||
|
|
||
|
// new http client
|
||
|
hConn, err := http.NewClient(
|
||
|
context.Background(),
|
||
|
http.WithMiddleware(
|
||
|
recovery.Recovery(),
|
||
|
),
|
||
|
http.WithEndpoint("discovery:///helloworld"),
|
||
|
http.WithDiscovery(r),
|
||
|
// 这里使用p2c算法的balancer+静态version=2.0.0的Filter组成一个selector
|
||
|
http.WithSelector(
|
||
|
p2c.New(p2c.WithFilter(filter.Version("2.0.0"))),
|
||
|
),
|
||
|
)
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
defer hConn.Close()
|
||
|
hClient := helloworld.NewGreeterHTTPClient(hConn)
|
||
|
|
||
|
for {
|
||
|
time.Sleep(time.Second)
|
||
|
callGRPC(gClient)
|
||
|
callHTTP(hClient)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func callGRPC(client helloworld.GreeterClient) {
|
||
|
reply, err := client.SayHello(context.Background(), &helloworld.HelloRequest{Name: "kratos"})
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
log.Printf("[grpc] SayHello %+v\n", reply)
|
||
|
}
|
||
|
|
||
|
func callHTTP(client helloworld.GreeterHTTPClient) {
|
||
|
reply, err := client.SayHello(context.Background(), &helloworld.HelloRequest{Name: "kratos"})
|
||
|
if err != nil {
|
||
|
log.Fatal(err)
|
||
|
}
|
||
|
log.Printf("[http] SayHello %s\n", reply.Message)
|
||
|
}
|