dubbo 框架

2.1 dubbo  

  Apache Dubbo (incubating) |ˈdʌbəʊ| 是一款高性能、轻量级的开源 Java RPC 框架,它提
供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和

发现。

  Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案、 服
务治理方案。
官网:http://dubbo.apache.org/zh-cn/

快速开始文档地址:http://dubbo.apache.org/zh-cn/docs/user/quick-start.html

面向接口代理:调用接口的方法,在 A 服务器调用 B 服务器的方法,由 dubbo 实现对 B 的
调用,无需关心实现的细节,就像 MyBatis 访问 Dao 的接口,可以操作数据库一样。不用关
心 Dao 接口方法的实现。这样开发是方便,舒服的。

2.2 基本架构

架构图:

provider:提供者,供应商,提供程序

consumer:消费者

subscribe:订阅

notify:通知

invoke:调用,呼叫

  服务提供者( (Provider) ):暴露服务的服务提供方,服务提供者在启动时,向注册中心注
册自己提供的服务。
  服务消费者( (Consumer ): 调用远程服务的服务消费方,服务消费者在启动时,向注册
中心订阅自己所需的服务,服务消费者,从提供者地址列表中,基于软负载均衡算法,选一
台提供者进行调用,如果调用失败,再选另一台调用。
  注册中心( (Registry) ):注册中心返回服务提供者地址列表给消费者,如果有变更,注册
中心将基于长连接推送变更数据给消费者
  监控中心( (Monitor) ):服务消费者和提供者,在内存中累计调用次数和调用时间,定时
每分钟发送一次统计数据到监控中心

调用关系说明:
⚫ 服务容器负责启动,加载,运行服务提供者。
⚫ 服务提供者在启动时,向注册中心注册自己提供的服务。
⚫ 服务消费者在启动时,向注册中心订阅自己所需的服务。
⚫ 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送
变更数据给消费者。
⚫ 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如
果调用失败,再选另一台调用。

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

2.3 dubbo  支持的协议

  支持多种协议:dubbo , hessian , rmi , http, webservice , thrift , memcached , redis。
dubbo 官方推荐使用 dubbo 协议。dubbo 协议默认端口 20880
使用 dubbo 协议,spring 配置文件加入:
<dubbo:protocol name="dubbo" port="20880" />

2.5直连方式 dubbo

  点对点的直连项目:消费者直接访问服务提供者,没有注册中心。消费者必须指定服务
提供者的访问地址(url)。
消费者直接通过 url 地址访问固定的服务提供者。这个 url 地址是不变的。

2.5.1 实现目标

2.5.2 实现方式

以 JavaSE 为例,服务提供者,服务消费者都是 JavaSE 项目

(1) 创建服务提供者: 订单服务

A 、 建 新建 java project

项目名称: link-orderservice-provider
设置 version 为 1.0.0

B 、 maven pom.xml

<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-context</artifactId>
  <version>4.3.16.RELEASE</version>
</dependency>
<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>dubbo</artifactId>
  <version>2.6.2</version>
</dependency>

在<build>中加入 plugin

猜你喜欢

转载自www.cnblogs.com/Tpf386/p/11101424.html