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.
84 lines
2.1 KiB
84 lines
2.1 KiB
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.WithFilter(
|
|
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)
|
|
}
|
|
|