Kratos,RPC服务调用过程

本文详细解析了Kratos RPC服务的调用过程,从客户端发起请求开始,通过Warden注册Handler到RPC服务,深入探讨了服务端拦截器grpc.UnaryServerInterceptor的运作方式,包括UnaryHandler和UnaryServerInterceptor的角色。通过分析 proto 文件生成的代码,展示了gRPC如何根据请求方法找到对应Handler执行,并解释了如何在gRPC server内部注入和执行拦截器,最终串联完成服务端拦截器的逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先,客户端发起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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ccheers_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值