博客
关于我
SpringBoot2.0 整合 Dubbo框架 ,实现RPC服务远程调用
阅读量:407 次
发布时间:2019-03-06

本文共 4016 字,大约阅读时间需要 13 分钟。

本文源码: ||

一、Dubbo框架简介

1、框架依赖

图例说明:
1)图中小方块 Protocol, Cluster, Proxy, Service, Container, Registry, Monitor 代表层或模块,蓝色的表示与业务有交互,绿色的表示只对 Dubbo 内部交互。
2)图中背景方块 Consumer, Provider, Registry, Monitor 代表部署逻辑拓扑节点。
3)图中蓝色虚线为初始化时调用,红色虚线为运行时异步调用,红色实线为运行时同步调用。
4)图中只包含 RPC 的层,不包含 Remoting 的层,Remoting 整体都隐含在 Protocol 中。

2、核心角色说明

1)Provider 暴露服务的服务提供方

2)Consumer 调用远程服务的服务消费方(负载均衡)
3)Registry 服务注册与发现的注册中心(监控、心跳、踢出、重入)
4)Monitor 服务消费者和提供者在内存中累计调用次数和调用时间,主动定时每分钟发送一次统计数据到监控中心。
5)Container 服务运行容器:远程调用、序列化

二、与SpringBoot2.0整合

1、核心依赖

com.alibaba.boot
dubbo-spring-boot-starter
0.2.0

2、项目结构说明

结构说明

dubbo-consume:服务消费方dubbo-provider:服务提供方dubbo-common:公共代码块,Dubbo接口,实体类

3、核心配置

1)提供方配置

server:  tomcat:    uri-encoding: UTF-8    max-threads: 1000    min-spare-threads: 30  port: 7007  connection-timeout: 5000msspring:  application:    name: block-dubbo-provider# Dubbo 配置文件dubbo:  application:    name: block-dubbo-provider  registry:    address: 127.0.0.1:2181    protocol: zookeeper  protocol:    name: dubbo    port: 20880  scan:    base-packages: com.boot.consume

2)消费方配置

server:  tomcat:    uri-encoding: UTF-8    max-threads: 1000    min-spare-threads: 30  port: 7008  connection-timeout: 5000msspring:  application:    name: block-dubbo-consume# Dubbo 配置文件dubbo:  application:    name: block-dubbo-consume  registry:    address: 127.0.0.1:2181    protocol: zookeeper

三、演示案例

1、服务远程调用

1)提供方服务接口

  • 注意这里的注解
  • com.alibaba.dubbo.config.annotation.Service
@Service@Componentpublic class DubboServiceImpl implements DubboService {    private static Logger LOGGER = LoggerFactory.getLogger(DubboServiceImpl.class) ;    @Override    public String getInfo(String param) {        LOGGER.info("字符参数:{}",param);        return "[Hello,Cicada]";    }    @Override    public UserEntity getUserInfo(UserEntity userEntity) {        LOGGER.info("实体类参数:{}",userEntity);        return userEntity;    }}

2)消费方接口

  • 注意这里注解
  • com.alibaba.dubbo.config.annotation.Reference
  • org.springframework.stereotype.Service
@Servicepublic class ConsumeService implements DubboService {    @Reference    private DubboService dubboService ;    @Override    public String getInfo(String param) {        return dubboService.getInfo(param);    }    @Override    public UserEntity getUserInfo(UserEntity userEntity) {        return dubboService.getUserInfo(userEntity);    }}

2、接口超时配置

该配置可以在服务提供方配置,也可以在服务消费方配置,这里演示在提供方的配置。

注解:timeout
1)服务接口注解

@Service(timeout = 2000)@Componentpublic class DubboServiceImpl implements DubboService {}

2)消费方调用

@Override public String timeOut(Integer time) {     return dubboService.timeOut(time); }

3)测试接口

服务超时抛出异常

com.alibaba.dubbo.remoting.TimeoutException

3、接口多版本配置

1)服务提供方

相同接口提供两个版本实现。注解:version。
版本一:

@Service(version = "1.0.0")@Componentpublic class VersionOneImpl implements VersionService {    @Override    public String getVersion() {        return "{当前版本:1.0.0}";    }}

版本二:

@Service(version = "2.0.0")@Componentpublic class VersionTwoImpl implements VersionService {    @Override    public String getVersion() {        return "{当前版本:2.0.0}";    }}

2)消费方调用

通过@Reference(version)注解,将指向不同版本的接口实现。

@Servicepublic class VersionServiceImpl implements VersionService {    @Reference(version = "1.0.0")    private VersionService versionService1 ;    @Reference(version = "2.0.0")    private VersionService versionService2 ;    @Override    public String getVersion() {        return versionService1.getVersion();    }    public String version2 (){        return versionService2.getVersion() ;    }}

以上案例都是参照Dubbo官网的流程编写的,Dubbo许多强大功能都可以参考官网一步步的配置。

四、源代码地址

GitHub地址:知了一笑https://github.com/cicadasmile/middle-ware-parent码云地址:知了一笑https://gitee.com/cicadasmile/middle-ware-parent

阅读标签

【】【】【】【】【】

【】【】【】【】【】
【】【】【 】

推荐阅读:编程体系分类整理

序号 项目名称 GitHub地址 GitEE地址 推荐指数
01 Java描述设计模式,算法,数据结构 ☆☆☆☆☆
02 Java基础、并发、面向对象、Web开发 ☆☆☆☆
03 SpringCloud微服务基础组件案例详解 ☆☆☆
04 SpringCloud微服务架构实战综合案例 ☆☆☆☆☆
05 SpringBoot框架基础应用入门到进阶 ☆☆☆☆
06 SpringBoot框架整合开发常用中间件 ☆☆☆☆☆
07 数据管理、分布式、架构设计基础案例 ☆☆☆☆☆
08 大数据系列、存储、组件、计算等框架 ☆☆☆☆☆

转载地址:http://unqkz.baihongyu.com/

你可能感兴趣的文章
cmp命令
查看>>
Linux 磁盘管理(df fu fdisk mkfs mount)
查看>>
老Python总结的字典相关知识
查看>>
jQuery的事件绑定与触发 - 学习笔记
查看>>
Linux上TCP的几个内核参数调优
查看>>
记一次讲故事机器人的开发-我有故事,让机器人来读
查看>>
seo 回忆录百度基本概念(一)
查看>>
kettle 执行 kjb 临时文件夹 /tmp permission denied 问题
查看>>
netcore中使用session
查看>>
Android 开发学习进程0.25 自定义控件
查看>>
多媒体文件格式全解说(下)--图片
查看>>
淘宝WAP版小BUG分析
查看>>
asp.net打印网页后自动关闭网页【无需插件】
查看>>
【Maven】POM基本概念
查看>>
【Java思考】Java 中的实参与形参之间的传递到底是值传递还是引用传递呢?
查看>>
【设计模式】单例模式
查看>>
远程触发Jenkins的Pipeline任务的并发问题处理
查看>>
Web应用程序并发问题处理的一点小经验
查看>>
entity framework core在独立类库下执行迁移操作
查看>>
Asp.Net Core 2.1+的视图缓存(响应缓存)
查看>>