- 1:Dubbo简介
- 1:简介
- 2:发展历史
- 3:Dubbo架构
- 2:Dubbo支持的协议
- 1.Dubbo协议(官方推荐协议)
- 2.RMI(Remote Method Invocation)协议
- 3.Hessian协议
- 3:Dubbo支持的注册中心
- 1.Zookeeper(官方推荐)
- 2.Multicast
- 3.Redis
- 4.Simple
- 4:Dubbo的hello world
- 1:环境准备
- 2:需求
- 3:gmall-interface:公共接口层(model,service,exception…)
- 4:provider:gmall-user:用户模块(对用户接口的实现)
- 5:consumer:gmall-order-web:订单模块(调用用户模块)
- 6:注解版
- 5:整合springboot
- 1:引入依赖
- 2:配置dubbo
- 3:编码-注意注解
- 1:服务提供者
- 2:服务消费者
Apache Dubbo (incubating) |ˈdʌbəʊ| 是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。
Apache Dubbo 是一个高可用的,基于Java的开源RPC框架。
Dubbo框架不仅仅是具备RPC访问功能,还包含服务治理功能。
3:Dubbo架构Dubbo是最开始是阿里巴巴内部使用的RPC框架。
2011年对外提供。
2012年停止更新。
2017年开始继续更新。
2019年捐献给Apache,由Apache维护2.7以上版本。
- 虚线
虚线表示异步,实线表示同步。异步不阻塞线程性能高,同步阻塞线程必须等待响应结果才能继续执行,相对性能低。
-
Provider
提供者。编写持久层和事务代码。 -
Container
容器(Spring容器),Dubbo完全基于Spring实现的。 -
Registry
注册中心。放置所有Provider对外提供的信息。包含Provider的IP,访问端口,访问遵守的协议,对外提供的接口,接口中有哪些方法等相关信息。 -
Consumer
消费者(RPC调用者,SOA调用服务的项目)开发中也是一个项目,编写service和controller(还可以报页面等)。调用XXXXServiceImpl中的方法。 -
Monitor
监控中心。监控Provider的压力情况等。每隔2分钟Consumer和Provider会把调用次数发送给Monitor,由Monitor进行统计。
执行流程
- start:启动Spring容器时会把Provider启动。
- register:把Provider相关信息注册到Registry里
- subscribe:Consumer从Registry中订阅Provider的信息
- notify:通知给Consumer
- invoke:Consumer根据Registry通知的信息进行调用Provider中方法。
- count:Consumer和Provider把调用次数信息异步发送给Monitor进行统计。
优点:
采用NIO复用单一长连接,并使用线程池并发处理请求,减少握手和加大并发效率,性能较好(推荐使用)
缺点:
大文件上传时,可能出现问题(不使用Dubbo文件上传)
优点:
JDK自带的能力。
缺点:
偶尔连接失败.
优点:
可与原生Hessian互 *** 作,基于HTTP协议
缺点:
需hessian.jar支持,http短连接的开销大
1) 优点:
支持分布式.很多周边产品.
2) 缺点:
受限于Zookeeper软件的稳定性.Zookeeper专门分布式辅助软件,稳定较优
2.Multicast 1) 优点:
去中心化,不需要单独安装软件.
2) 缺点:
2.2.1 Provider和Consumer和Registry不能跨机房(路由)
3.Redis 1) 优点:
支持集群,性能高
2) 缺点:
要求服务器时间同步.否则可能出现集群失败问题.
4.Simple 1) 优点:
标准RPC服务.没有兼容问题
2) 缺点:
不支持集群.
4:Dubbo的hello worlddubbo本身并不是一个服务软件。它其实就是一个jar包能够帮你的java程序连接到zookeeper,并利用zookeeper消费、提供服务。所以你不用在Linux上启动什么dubbo服务。直接使用java代码调用即可;
1:环境准备虽然Dubbo是直接使用jar引入的,但是dubbo的注册中心是zookeeper,所以我们需要安装zookeeper,在此我写过一片博客;大家可以参考下:zookeeper的安装和使用
2:需求某个电商系统,订单服务需要调用用户服务获取某个用户的所有地址;
我们现在 需要创建两个服务模块进行测试
模块 | 功能 |
---|---|
订单服务web模块 | 创建订单等 |
用户服务service模块 | 查询用户地址等 |
测试预期结果:
订单服务web模块在A服务器,用户服务模块在B服务器,A可以远程调用B的功能。即订单业务中查询用户地址;
1、引入dubbo
<dependency>
<groupId>com.alibabagroupId>
<artifactId>dubboartifactId>
<version>2.6.2version>
dependency>
<dependency>
<groupId>com.101tecgroupId>
<artifactId>zkclientartifactId>
<version>0.10version>
dependency>
<dependency>
<groupId>org.apache.curatorgroupId>
<artifactId>curator-frameworkartifactId>
<version>2.12.0version>
dependency>
2、配置提供者
<dubbo:application name="gmall-user">dubbo:application>
<dubbo:registry address="zookeeper://118.24.44.169:2181" />
<dubbo:protocol name="dubbo" port="20880" />
<dubbo:service interface="com.atguigu.gmall.service.UserService" ref="userServiceImpl" />
3:编码
1、引入dubbo和其他依赖
<dependency>
<groupId>com.atguigu.dubbogroupId>
<artifactId>gmall-interfaceartifactId>
<version>0.0.1-SNAPSHOTversion>
dependency>
<dependency>
<groupId>com.alibabagroupId>
<artifactId>dubboartifactId>
<version>2.6.2version>
dependency>
<dependency>
<groupId>com.101tecgroupId>
<artifactId>zkclientartifactId>
<version>0.10version>
dependency>
<dependency>
<groupId>org.apache.curatorgroupId>
<artifactId>curator-frameworkartifactId>
<version>2.12.0version>
dependency>
2、配置消费者信息
<dubbo:application name="gmall-order-web">dubbo:application>
<dubbo:registry address="zookeeper://118.24.44.169:2181" />
<dubbo:reference id="userService" interface="com.atguigu.gmall.service.UserService">dubbo:reference>
3、编码
2、测试
public class OrderService {
UserService userService;
/**
* 初始化订单,查询用户的所有地址并返回
* @param userId
* @return
*/
public List<UserAddress> initOrder(String userId){
return userService.getUserAddressList(userId);
}
}
6:注解版
1、服务提供方
<dubbo:application name="gmall-user"></dubbo:application>
<dubbo:registry address="zookeeper://118.24.44.169:2181" />
<dubbo:protocol name="dubbo" port="20880" />
<dubbo:annotation package="com.atguigu.gmall.user.impl"/>
import com.alibaba.dubbo.config.annotation.Service;
import com.atguigu.gmall.bean.UserAddress;
import com.atguigu.gmall.service.UserService;
import com.atguigu.gmall.user.mapper.UserAddressMapper;
@Service //使用dubbo提供的service注解,注册暴露服务
public class UserServiceImpl implements UserService {
@Autowired
UserAddressMapper userAddressMapper;
2、服务消费方
<dubbo:application name="gmall-order-web"></dubbo:application>
<dubbo:registry address="zookeeper://118.24.44.169:2181" />
<dubbo:annotation package="com.atguigu.gmall.order.controller"/>
@Controller
public class OrderController {
@Reference //使用dubbo提供的reference注解引用远程服务
UserService userService;
5:整合springboot
1:引入依赖
#引入spring-boot-starter以及dubbo和curator的依赖
<dependency>
<groupId>com.alibaba.bootgroupId>
<artifactId>dubbo-spring-boot-starterartifactId>
<version>0.2.0version>
dependency>
2:配置dubbo
#提供者配置:
dubbo.application.name=gmall-user
dubbo.registry.protocol=zookeeper
dubbo.registry.address=192.168.67.159:2181
dubbo.scan.base-package=com.gmall
dubbo.protocol.name=dubbo
#application.name就是服务名,不能跟别的dubbo提供端重复
#registry.protocol 是指定注册中心协议
#registry.address 是注册中心的地址加端口号
#protocol.name 是分布式固定是dubbo,不要改。
#base-package 注解方式要扫描的包
#消费者配置:
dubbo.application.name=gmall-order-web
dubbo.registry.protocol=zookeeper
dubbo.registry.address=192.168.67.159:2181
dubbo.scan.base-package=com.gmall
dubbo.protocol.name=dubbo
3:编码-注意注解
1:服务提供者
@Service //注解是apache的注解。
public class DemoDubboServiceImpl implements DemoDubboService {
@Override
public String demo() {
System.out.println("demo方法");
return "123";
}
}
2:服务消费者
@Service //这是springboot的注解
public class DemoServiceImpl implements DemoService {
@Reference //这是dubbo的注解
private DemoDubboService demoDubboService;
@Override
public String consumerDemo() {
return demoDubboService.demo();
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)