版权声明:本文为博主原创文章,未经博主允许不得转载。 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" />
可以配置在消费者端
也可以配置在服务者端
在实际开发中,一般放在接口调用之前