本文主要研究一下dubbo-go的EchoFiltercode
dubbo-go-v1.4.2/filter/filter_impl/echo_filter.goit
const ( // ECHO echo module name ECHO = "echo" ) func init() { extension.SetFilter(ECHO, GetFilter) } // EchoFilter // RPCService need a Echo method in consumer, if you want to use EchoFilter // eg: // Echo func(ctx context.Context, arg interface{}, rsp *Xxx) error type EchoFilter struct{}
dubbo-go-v1.4.2/filter/filter_impl/echo_filter.goio
// Invoke ... func (ef *EchoFilter) Invoke(ctx context.Context, invoker protocol.Invoker, invocation protocol.Invocation) protocol.Result { logger.Infof("invoking echo filter.") logger.Debugf("%v,%v", invocation.MethodName(), len(invocation.Arguments())) if invocation.MethodName() == constant.ECHO && len(invocation.Arguments()) == 1 { return &protocol.RPCResult{ Rest: invocation.Arguments()[0], Attrs: invocation.Attachments(), } } return invoker.Invoke(ctx, invocation) }
dubbo-go-v1.4.2/filter/filter_impl/echo_filter.gomodule
// OnResponse ... func (ef *EchoFilter) OnResponse(_ context.Context, result protocol.Result, _ protocol.Invoker, _ protocol.Invocation) protocol.Result { return result }
dubbo-go-v1.4.2/filter/filter_impl/echo_filter.godubbo
// GetFilter ... func GetFilter() filter.Filter { return &EchoFilter{} }
EchoFilter的Invoke方法判斷invocation.MethodName是不是echo,且有一個參數,是的話則返回protocol.RPCResultbug