zoukankan      html  css  js  c++  java
  • EchoService

    dubbo为consumer端的代理对象实现了EchoService接口。

    使用示例:

    <dubbo:reference id="hello" interface="com.zhang.HelloService" check="false" />
    EchoService echoService = (EchoService) appCtx.getBean("hello");
    Object str = echoService.$echo("zhang");

    原理:

    public interface EchoService {
        Object $echo(Object message);
    }
    //AbstractProxyFactory
    public <T> T getProxy(Invoker<T> invoker) throws RpcException {
        Class<?>[] interfaces = null;
        String config = invoker.getUrl().getParameter("interfaces");
        if (config != null && config.length() > 0) {
            String[] types = Constants.COMMA_SPLIT_PATTERN.split(config);
            if (types != null && types.length > 0) {
                interfaces = new Class<?>[types.length + 2];
                interfaces[0] = invoker.getInterface();
                interfaces[1] = EchoService.class;
                for (int i = 0; i < types.length; i ++) {
                    interfaces[i + 1] = ReflectUtils.forName(types[i]);
                }
            }
        }
        if (interfaces == null) {
            //加入了EchoService接口
            interfaces = new Class<?>[] {invoker.getInterface(), EchoService.class};
        }
        //JavassistProxyFactory和JdkProxyFactory分别实现EchoService接口
        return getProxy(invoker, interfaces);
    }

    provider在EchoFilter中处理$echo请求:

    @Activate(group = Constants.PROVIDER, order = -110000)
    public class EchoFilter implements Filter {
        public Result invoke(Invoker<?> invoker, Invocation inv) throws RpcException {
            if(inv.getMethodName().equals(Constants.$ECHO) 
            && inv.getArguments() != null && inv.getArguments().length == 1) return new RpcResult(inv.getArguments()[0]); return invoker.invoke(inv); } }
  • 相关阅读:
    正则表达式
    跨域请求/SpringMVC拦截器
    批量导出
    什么是2MSL以及TIME_WAIT的作用
    使用jstack精确找到异常代码的
    nettry 入站事件如何传递到下一个handler
    netty 引用计数器 ,垃圾回收
    elasticsearch 查询优化
    Spark性能优化指南-高级篇(spark shuffle)
    Broadcast与map进行join,避免shuffle,从而优化spark
  • 原文地址:https://www.cnblogs.com/allenwas3/p/8400075.html
Copyright © 2011-2022 走看看