Dubbo本地存根

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/nangeali/article/details/82526988

本地存根

参考文档
http://dubbo.apache.org/zh-cn/docs/user/demos/local-stub.html
这里写图片描述
本地存根
可以提前验证参数
调用失败之后,伪造容错数据等

消费方

写一个本地存根Stub的实现
必须,提供一个有参构造器

有参构造器,传入的是远程接口的代理实现
不需要去传这个参数,Dubbo默认自动传递进来

可以添加判断
判断通过之后,再调用远程服务

package com.foo;
public class BarServiceStub implements BarService { 
    private final BarService barService;

    // 构造函数传入真正的远程代理对象
    public (BarService barService) {
        this.barService = barService;
    }

    public String sayHello(String name) {
        // 此代码在客户端执行, 你可以在客户端做ThreadLocal本地缓存,或预先验证参数是否合法,等等
        try {
            return barService.sayHello(name);
        } catch (Exception e) {
            // 你可以容错,可以做任何AOP拦截事项
            return "容错数据";
        }
    }
}

配置本地存根

本地存根写完之后,需要配置

<dubbo:service interface="com.foo.BarService" stub="true" />

或者

<dubbo:service interface="com.foo.BarService" stub="com.foo.BarServiceStub" />

可以配置在消费者端
也可以配置在服务者端
在实际开发中,一般放在接口调用之前

猜你喜欢

转载自blog.csdn.net/nangeali/article/details/82526988
今日推荐