Dubbo-02-Dubbo简介和安装

Dubbo-02-Dubbo简介和安装,第1张

文章目录
  • 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:服务消费者

1:Dubbo简介 1:简介

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

Apache Dubbo 是一个高可用的,基于Java的开源RPC框架。
Dubbo框架不仅仅是具备RPC访问功能,还包含服务治理功能。

2:发展历史

Dubbo是最开始是阿里巴巴内部使用的RPC框架。
​ 2011年对外提供。
​ 2012年停止更新。
​ 2017年开始继续更新。
​ 2019年捐献给Apache,由Apache维护2.7以上版本。

3:Dubbo架构

  • 虚线

​ 虚线表示异步,实线表示同步。异步不阻塞线程性能高,同步阻塞线程必须等待响应结果才能继续执行,相对性能低。

  • Provider
    ​ 提供者。编写持久层和事务代码。

  • Container
    ​ 容器(Spring容器),Dubbo完全基于Spring实现的。

  • Registry
    ​ 注册中心。放置所有Provider对外提供的信息。包含Provider的IP,访问端口,访问遵守的协议,对外提供的接口,接口中有哪些方法等相关信息。

  • Consumer
    ​ 消费者(RPC调用者,SOA调用服务的项目)开发中也是一个项目,编写service和controller(还可以报页面等)。调用XXXXServiceImpl中的方法。

  • Monitor
    ​ 监控中心。监控Provider的压力情况等。每隔2分钟Consumer和Provider会把调用次数发送给Monitor,由Monitor进行统计。

执行流程

  1. start:启动Spring容器时会把Provider启动。
  2. register:把Provider相关信息注册到Registry里
  3. subscribe:Consumer从Registry中订阅Provider的信息
  4. notify:通知给Consumer
  5. invoke:Consumer根据Registry通知的信息进行调用Provider中方法。
  6. count:Consumer和Provider把调用次数信息异步发送给Monitor进行统计。
2:Dubbo支持的协议 1.Dubbo协议(官方推荐协议)

​ 优点:
​ 采用NIO复用单一长连接,并使用线程池并发处理请求,减少握手和加大并发效率,性能较好(推荐使用)

​ 缺点:
​ 大文件上传时,可能出现问题(不使用Dubbo文件上传)

2.RMI(Remote Method Invocation)协议

​ 优点:
​ JDK自带的能力。

​ 缺点:
​ 偶尔连接失败.

3.Hessian协议

​ 优点:
​ 可与原生Hessian互 *** 作,基于HTTP协议

​ 缺点:
​ 需hessian.jar支持,http短连接的开销大

3:Dubbo支持的注册中心 1.Zookeeper(官方推荐)

​ 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 world

dubbo本身并不是一个服务软件。它其实就是一个jar包能够帮你的java程序连接到zookeeper,并利用zookeeper消费、提供服务。所以你不用在Linux上启动什么dubbo服务。直接使用java代码调用即可;

1:环境准备

虽然Dubbo是直接使用jar引入的,但是dubbo的注册中心是zookeeper,所以我们需要安装zookeeper,在此我写过一片博客;大家可以参考下:zookeeper的安装和使用

2:需求

某个电商系统,订单服务需要调用用户服务获取某个用户的所有地址;
我们现在 需要创建两个服务模块进行测试

模块功能
订单服务web模块创建订单等
用户服务service模块查询用户地址等

测试预期结果:
订单服务web模块在A服务器,用户服务模块在B服务器,A可以远程调用B的功能。即订单业务中查询用户地址;

3:gmall-interface:公共接口层(model,service,exception…)

4:provider:gmall-user:用户模块(对用户接口的实现)

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:编码

5:consumer:gmall-order-web:订单模块(调用用户模块)

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();
    }
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/919556.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-16
下一篇 2022-05-16

发表评论

登录后才能评论

评论列表(0条)

保存