Dubbo和Zookeeper的基本使用

1.背景介绍

Dubbo是什么?

1、一款分布式服务框架;

2、高性能和透明化的RPC远程服务调用方案;

3、SOA服务治理方案。

 

其核心部分包含:

1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。

2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。

3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

 

Dubbo能做什么?

1、Dubbo采用全spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可;

2、软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。

3、服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

 

2.知识剖析

dubbo的架构

Dubbo和Zookeeper的基本使用_第1张图片

节点角色说明: 

Provider: 暴露服务的服务提供方。

Consumer: 调用远程服务的服务消费方。

Registry: 服务注册与发现的注册中心。

Monitor: 统计服务的调用次数和调用时间的监控中心。

Container: 服务运行容器。

 

调用关系说明:

0.服务容器负责启动,加载,运行服务提供者。

1. 服务提供者在启动时,向注册中心注册自己提供的服务。

2. 服务消费者在启动时,向注册中心订阅自己所需的服务。

3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。

4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。

5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

 

Dubbo注册中心

通过将服务统一管理起来,可以有效地优化内部应用对服务发布/使用的流程和管理。服务注册中心可以通过特定协议来完成服务对外的统一。

Dubbo提供的注册中心有如下几种类型可供选择:

Multicast注册中心

Zookeeper注册中心

Redis注册中心

Simple注册中心

Zookeeper介绍与安装

Zookeeper是一个分布式服务协调框架,是树型的目录服务的数据存储,能做到集群管理数据 ,这里能很好的作为Dubbo服务的注册中心。

Dubbo能与Zookeeper做到集群部署,当提供者出现断电等异常停机时,Zookeeper注册中心能自动删除提供者信息,当提供者重启时,能自动恢复注册数据,以及订阅请求。

 

3.常见问题

1、Dubbo优缺点?

优点:1、透明化的远程方法调用,只需简单配置,没有任何API侵入。2、软负载均衡及容错机制 。3、服务注册中心自动注册 & 配置管理 。4、服务接口监控与治理 ,Dubbo-admin与Dubbo-monitor提供了完善的服务接口管理与监控功能,针对不同应用的不同接口,可以进行 多版本,多协议,多注册中心管理。

缺点: 只支持JAVA语言

 

2、Dubbo支持多种协议?

Hessian协议、HTTP协议、WebService协议(都是基于http短连接的);

Dubbo协议、RMI协议(tcp长连接);

Thrift协议、Memcached协议、Redis协议。

 

3、spring cloud 与 dubbo?

从整体架构上来看,二者模式接近,都需要服务提供方,注册中心,服务消费方。

从核心要素来看,Spring Cloud 更胜一筹,在开发过程中只要整合 Spring Cloud 的子项目就可以顺利的完成各种组件的融合,而 Dubbo 却需要通过实现各种 Filter 来做定制,开发成本以及技术难度略高。

从通讯协议和性能来看,Dubbo 支持各种通信协议,而且消费方和服务方使用长链接方式交互;Spring Cloud 使用 HTTP 协议的 REST API;通信速度上略胜 Spring-Cloud,如果对于系统的响应时间有严格要求,长链接更合适。

从服务依赖方式来看,Dubbo 服务依赖略重,需要有完善的版本管理机制,但是程序入侵少。而 Spring Cloud 通过 Json 交互,省略了版本管理的问题,但是具体字段含义需要统一管理,自身 Rest API 方式交互,为跨平台调用奠定了基础。

 

4、http和socket之长连接和短连接区别?

(1)短连接:

连接->传输数据->关闭连接

简单地说就是指每次请求都新建一个SOCKET,处理完一个请求就直接关闭socket。

(2)长连接

连接->传输数据->保持连接 -> 传输数据-> ... ->关闭连接。

客户端和服务端都是用一个socket对象,建立socket连接后不管是否使用都保持连接,安全性较差。

你可能感兴趣的:(dubbo)