首先,客户端发起RPC调用请求
// SayHello say hello.
func (d *dao) SayHello(c context.Context, req *api.HelloReq) (resp *empty.Empty, err error) {
if resp, err = d.demoClient.SayHello(c, req); err != nil {
err = errors.Wrapf(err, "%v", req.Name)
}
return
}
RPC服务将会在注册方法中寻找对应方法然后调用
type demoClient struct {
cc *grpc.ClientConn
}
func (c *demoClient) SayHelloURL(ctx context.Context, in *HelloReq, opts ...grpc.CallOption) (*HelloResp, error) {
out := new(HelloResp)
err := c.cc.Invoke(ctx, "/demo.service.v1.Demo/SayHelloURL", in, out, opts...)
if err != nil {
return nil, err
}
return out, nil
}
接下来是Kratos的RPC服务初始化流程
首先Warden将各种Handler注册进RPC服务中
var _Demo_serviceDesc = grpc.ServiceDesc{
ServiceName: "demo.service.v1.Demo",
HandlerType: (*DemoServer)(nil),
Methods