1、本地存根
面试官:我看你简历上写的精通Dubbo,那你能说一下Dubbo本地存根是什么吗?
我:我认为本地存根类似于AOP面向切面来实现一些功能,但是区别在于是在消费端调用服务端的时候在消费端执行的一些逻辑。
比如我们消费端在调用服务端之前可以在消费端进行参数的验证,在调用服务端之后如果出现异常,可以在消费端执行一些自定义的异常处理。
官网的解释是这样的:在 Dubbo 中利用本地存根在客户端执行部分逻辑
远程服务后,客户端通常只剩下接口,而实现全在服务器端,但提供方有些时候想在客户端也执行部分逻辑,比如:做 ThreadLocal 缓存,提前验证参数,调用失败后伪造容错数据等等,此时就需要在 API 中带上 Stub,客户端生成 Proxy 实例,会把 Proxy 通过构造函数传给 Stub 1,然后把 Stub 暴露给用户,Stub 可以决定要不要去调 Proxy。
在 spring 配置文件中按以下方式配置:
<dubbo:service interface="com.foo.BarService" stub="true" />
<dubbo:service interface="com.foo.BarService" stub="com.foo.BarServiceStub" />
提供 Stub 的实现
package com.foo;
public class BarServiceStub implements BarService {
private final BarService barService;
// 构造函数传入真正的远程代理对象
public BarServiceStub(BarService barService){
this.barService = barService;
}
public String sayHello(String name) {
// 此代码在客户端执行, 你可以在客户端做ThreadLocal本地缓存,或预先验证参数是否合法,等等
try {
return barService.sayHello(name);
} catch (Exception e) {
// 你可以容错,可以做任何AOP拦截事项
return "容错数据";
}
}
}
2、本地伪装
面试官:嗯,那你能说一下Dubbo本地伪装又是什么吗?
我:本地伪装顾名思义就是在消费端本地伪装一个返回参数直接返回给消费端,原本的流程是消费端调用服务端,服务端返回什么消费端就返回什么。
但是现在假如服务端停机了,消费端调用服务端就无法返回想返回的参数类型的数据了,这个时候我们可以在消费端伪装一个返回的参数,这样在调用服务端失败了,或者根本就不调用服务端的时候就可以直接返回本地伪装的数据。
假如现在有个业务场景,就是消费者调用服务端正常就返回参数,异常就返回一个"容错数据"。
那么我们首先在 spring 配置文件中按以下方式配置:这里相当于BarService是一个本地伪装接口
<dubbo:reference interface="com.foo.BarService" mock="true" />
然后我们在工程中提供 Mock本地伪装接口的 实现:
package com.foo;
public class BarServiceMock implements BarService {
public String sayHello(String name) {
// 你可以伪造容错数据,此方法只在出现RpcException时被执行
return "容错数据";
}
}
二、总结
这里的相关内容还没有整理完毕,文章后面持续更新,建议收藏。
文章中涉及到的命令大家一定要像我一样每个都敲几遍,只有在敲的过程中才能发现自己对命令是否真正的掌握了。
如果觉得我的文章还不错的话就点个赞吧