分布式服务治理技术Dubbo
1,为什么需要Dubbo? 因为是阿里开源项目,国内很多互联网公司都在用,已经经过很多线上考验。内部使用了 Netty、Zookeeper,保证了高性能高可用性。 使用Dubbo 可以将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,可用于提高业务复用灵活扩展,使前端应用能更快速的响应多变的市场需求。 下面这张图可以很清楚的诠释,最重要的一...
1,为什么需要Dubbo?
因为是阿里开源项目,国内很多互联网公司都在用,已经经过很多线上考验。内部使用了 Netty、Zookeeper,保证了高性能高可用性。
使用Dubbo 可以将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,可用于提高业务复用灵活扩展,使前端应用能更快速的响应多变的市场需求。
下面这张图可以很清楚的诠释,最重要的一点是,分布式架构可以承受更大规模的并发流量。
下面是 Dubbo 的服务治理图。
2,Dubbo的架构
3,Dubbo和SpringCloud有什么区别?
两个没关联,如果硬要说区别,有以下几点。
1)通信方式不同
Dubbo使用RPC通信,而SpringCloud使用是HTTP RESTFul 方式。
2)组成部分不同
4,dubbo都支持什么协议,推荐用哪种?
-
dubbo://(推荐)
-
rmi://
-
hessian://
-
http://
-
webservice://
-
thrift://
-
memcached://
-
redis://
-
rest://
5,Dubbo需要Web容器吗?
不需要,如果硬要用Web容器,只会增加复杂性,也浪费资源。
6,Dubbo内置了哪几种服务容器?
-
Spring Container
-
Jetty Container
-
Log4j Container
Dubbo的服务容器只是一个简单Main方法,并加载一个简单的Spring容器,用于暴露服务。
7,Dubbo里面有哪几种节点角色?
8,Dubbo默认使用什么注册中心,还有别的选择吗?
推荐使用Zookeeper作为注册中心,还有Redis,Multicast,Simple注册中心,但是不推荐。
9,Dobbo有哪几种配置方式?
1)Spring配置方式
2)Java API配置方式
10,Dubbo核心的配置有哪些?
配置之间的关系见下图。
11,在Provider上可以配置的Consumer端的属性有哪些?
1)timeout:方法调用超时
2)retries:失败重试次数,默认重试2次
3)loadbalance:负载均衡算法,默认随机
4)actives消费者端,最大并发调用限制
12,Dubbo启动时如果依赖的服务不可用会怎么样?
Dubbo缺省会在启动时检查依赖的服务时否可用,不可用时会抛出异常,阻止Spring初始化完成,默认check=“true”,可以通过check=“false”关闭检查。
13,Dubbo推荐使用什么序列化框架,你知道的还有哪些?
推荐使用Hessian序列化,还有Dubbo,FastJson,Java自带序列化。
14,Dubbo默认使用的是什么通信框架,还有别的选择吗?
Dubbo默认使用Netty框架,也是推荐的选择,另外内容还集成有Mina,Grizzly。
15,Dubbo有哪几种集群容错方案,默认是哪种?
16,Dubbo有哪几种负载均衡策略,默认是哪种?
17,注册了多个同一样的服务,如何测试指定的某一个服务呢?
可以配置环境点对点直连,绕过注册中心,将以服务接口为单位,忽略注册中心的提供者列表。
18,当一个服务接口有多种实现时怎么做?
当一个接口有多种实现时,可以用group属性来分组,服务提供方和消费方都指定同一个group即可。
19,Dubbo支持多服务协议吗?
Dubbo允许配置多协议,在不同服务上支持不同协议或者同一服务上同时支持多种协议。
20,服务上线怎么兼容旧版本?
可以用版本号(version)过渡,多个不同版本的服务注册到注册中心,版本号不同的服务相互间不引用。这个和服务分组的概念有一点类似。
21,Dubbo可以对结果进行缓存吗?
可以,Dubbo提供了申明式缓存,用于加速热门数据的访问速度,以减少用户加缓存的工作量。
22,Dubbo服务之间的调用是阻塞的吗?
默认是同步等待阻塞,支持异步调用。
Dubbo是基于NIO的非阻塞实现并行调用,客户端不需要启动多线程即可完成并行调用多个远程服务,相对多线程开销较小,异步调用会返回一个Future对象。
异步调用流程图如下。
23,Dubbo支持分布式事务吗?
目前暂时不支持,后续可能采用基于JTA/XA规范,如图所示。
24,Dubbo telnet命令能做什么?
dubbo通过telnet命令来进行服务治理,具体使用看这篇文章《dubbo服务调试管理实用命令》。
telnet localhost 8090
25,Dubbo支持服务降级吗?
Dubbo 2.2.0 以上版本支持。
26,Dubbo如何优雅停机?
Dubbo是通过JDK的ShutdownHook来完成优雅停机的,所以如果使用kill -9 PID等强制关闭指令,是不会执行优雅停机的,只有通过kill PID时,才会执行。
27,服务读写推荐的容错策略是怎样的?
读操作建议使用Failover失败自动切换,默认重试两次其他服务器。
写操作建议使用Failfast快速失败,发一次调用失败就立即报错。
28,Dubbo必须依赖的包有哪些?
Dubbo必须依赖JDK,其他可选。
29,Dubbo的管理控制台能做什么?
管理控制台主要包含:路由规则,动态配置,服务降级,访问控制,权重调整,负载均衡,等管理功能。
30,说说Dubbo服务暴露过程
Dubbo会在Spring实例化bean之后,在刷新容器最后一次发布ContextRefreshEvent 事件的时候,通过实现了ApplicationListener 的ServiceBean类进行回调onApplicationEvent 事件方法,Dubbo会在这个方法中调用ServiceBean 父类ServiceBean 的export方法,而该方法真正实现了服务的(异步或者非异步)发布。
31,Dubbo和Dubbox有什么区别?
Dubbox是继Dubbo停止维护后,当当网基于Dubbo做的一个扩展项目,如加了服务可restful调用,更新了开源组件等。
32,在使用过程中都遇到了些什么问题?
Dubbo的设计目的是为了满足高并发小数据量的rpc调用,在大数据量下的性能表现并不好,建议使用rmi或者http协议。
33,你觉得用Dubbo好还是SpringCloud好?
扩展性问题,没有好坏,只有适合不适合,不过我好像更倾向与使用Dubbo,SpringCould版本升级太快,组件更新替换太频繁,配置太繁琐
34,服务端发布流程
Spring对外留出的扩展
Dubbo是基于spring配置来实现服务发布的,那么一定是基于spring的扩展来写了一套自己的标签,那么spring是如何解析这些配置呢?具体细节就不在这里讲解,大家之前在学习spring源码的时候,应该有讲过。总的来说,就是可以通过spring的扩展机制来扩展自己的标签。大家在dubbo配置文件中看到的<dubbo:service>,就是属于自定义扩展标签要实现自定义扩展,有三个步骤(在spring中定义了两个接口,用来实现扩展)
1. NamespaceHandler: 注册一堆 BeanDefinitionParser,利用他们来进行解析
2. BeanDefinitionParser:用于解析每个 element 的内容
3. Spring 默认会加载 jar 包下的 META-INF/spring.handlers 文件寻找对应的 NamespaceHandler。
以下是 Dubbo-config 模块下的 dubbo-config-spring
Dubbo 的接入实现
Dubbo 中 spring 扩展就是使用 spring 的自定义类型,所以同样也有NamespaceHandler、BeanDefinitionParser。而 NamespaceHandler 是DubboNamespaceHandler
public class DubboNamespaceHandler extends
NamespaceHandlerSupport {
static {
Version. checkDuplicate (DubboNamespaceHandler.class);
}
public void init() {
registerBeanDefinitionParser("application", new
DubboBeanDefinitionParser(ApplicationConfig.class, true));
registerBeanDefinitionParser("module", new
DubboBeanDefinitionParser(ModuleConfig.class, true));
registerBeanDefinitionParser("registry", new
DubboBeanDefinitionParser(RegistryConfig.class, true));
registerBeanDefinitionParser("monitor", new
DubboBeanDefinitionParser(MonitorConfig.class, true));
registerBeanDefinitionParser("provider", new
DubboBeanDefinitionParser(ProviderConfig.class, true));
registerBeanDefinitionParser("consumer", new
DubboBeanDefinitionParser(ConsumerConfig.class, true));
registerBeanDefinitionParser("protocol", new
DubboBeanDefinitionParser(ProtocolConfig.class, true));
registerBeanDefinitionParser("service", new
DubboBeanDefinitionParser(ServiceBean.class, true));
registerBeanDefinitionParser("reference", new
DubboBeanDefinitionParser(ReferenceBean.class, false));
registerBeanDefinitionParser("annotation", new
DubboBeanDefinitionParser(AnnotationBean.class, true));
}
}
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)