仅用5分钟极速入门Dubbo使用教程

作者:Java识堂 时间:2022-08-08 12:08:55 

目录
  •  Dubbo是什么?

  • Dubbo能做什么?

  • 介绍

  • Api模块实现

  • producer模块实现

  • consumer模块实现

 Dubbo是什么?

Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有dubbo这样的分布式服务框架的需求,并且本质上是个服务调用的东东,说白了Dubbo就是个远程服务调用的分布式框架(告别Web Service模式中的WSdl,以服务者与消费者的方式在dubbo上注册)

其核心部分包含:
1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。
2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

Dubbo能做什么?

1.透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。     
2.软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。
3. 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

介绍

仅用5分钟极速入门Dubbo使用教程

在使用Dubbo开发时,我们一般将项目分为如下3个模块

api:将服务提供者和服务消费者都需要用到的接口放在api层
consumer:服务消费者
producer:服务提供者

假如有如下一个场景,我们需要查询用户的信息,用户请求发送到consumer这个服务,然后consumer这个服务调用producer这个服务获取到用户信息,并返回给用户

Api模块实现

用户信息封装到UserInfo类中,因为需要网络传输,所以需要实现序列化接口


public class UserInfo implements Serializable {

private String userId;
   private String phoneNum;
   private String userAddress;

public String getUserId() {
       return userId;
   }

public void setUserId(String userId) {
       this.userId = userId;
   }

public String getPhoneNum() {
       return phoneNum;
   }

public void setPhoneNum(String phoneNum) {
       this.phoneNum = phoneNum;
   }

public String getUserAddress() {
       return userAddress;
   }

public void setUserAddress(String userAddress) {
       this.userAddress = userAddress;
   }
}

用户信息接口,producer模块写这个接口的实现,consumer模块写这个接口的调用

producer模块实现

我们只需要引入对应的starter和zookeeper模块即可方便的使用dubbo


<dependency>
 <groupId>org.apache.dubbo</groupId>
 <artifactId>dubbo-spring-boot-starter</artifactId>
 <version>2.7.3</version>
</dependency>
<dependency>
 <groupId>org.apache.dubbo</groupId>
 <artifactId>dubbo-dependencies-zookeeper</artifactId>
 <version>2.7.6</version>
 <type>pom</type>
 <exclusions>
   <exclusion>
     <groupId>org.slf4j</groupId>
     <artifactId>slf4j-log4j12</artifactId>
   </exclusion>
 </exclusions>
</dependency>

producer模块写接口的实现即可


@Service
public class UserServiceImpl implements UserService {

@Override
   public UserInfo hello(String username) {
       UserInfo userInfo = new UserInfo();
       userInfo.setUserId("10");
       userInfo.setPhoneNum("15810554635");
       userInfo.setUserAddress("北京昌平");
       return userInfo;
   }
}

需要注意的一点是@Service注解是dubbo中的,初学者容易导入成spring框架的@Service,导致服务导出失败


import org.apache.dubbo.config.annotation.Service;

启动类上需要加上@EnableDubbo注解


@EnableDubbo
@SpringBootApplication
public class ProducerApp {
   public static void main(String[] args) {
       SpringApplication.run(ProducerApp.class, args);
   }
}

application.yaml


server:
 port: 8081

spring:
 application:
   name: springboot-dubbo-producer

dubbo:
 registry:
   # 注册中心地址及协议
   address: zookeeper://myhost:2181

在application.yaml指定服务启动的端口,服务名字和注册中心的地址

consumer模块实现

consumer端只需要在需要调用的接口上加上@Reference注解,即可调用到producer端


@RestController
public class UserController {

@Reference(check = false)
   private UserService userService;

@RequestMapping("hello")
   public UserInfo hello(@RequestParam("id") String id) {
       return userService.hello(id);
   }

}

@Reference中check=false表示启动的时候不去管UserService服务是否能正常提供服务,这个值默认为true,表示当UserService不能提供服务时,会导致consumer端启动失败

application.yaml


server:
 port: 8080

spring:
 application:
   name: springboot-dubbo-consumer

dubbo:
 registry:
   protocol: zookeeper
   address: myhost:2181

同样在application.yaml指定服务启动的端口,服务名字和注册中心的地址

curl http://localhost:8080/hello


{
 "userId": "10",
 "phoneNum": "158****4635",
 "userAddress": "北京昌平"
}

可以看到使用RPC框架后,调用远程方法和调用本地方法一样简单

本文github地址:https://github.com/erlieStar/dubbo-learning

来源:https://blog.csdn.net/zzti_erlie/article/details/117324153

标签:Dubbo,使用
0
投稿

猜你喜欢

  • 客户端实现蓝牙接收(C#)知识总结

    2021-11-21 22:17:11
  • 分享两种实现Winform程序的多语言支持的多种解决方案

    2023-10-17 21:24:17
  • Java数据结构之二叉排序树的实现

    2023-07-05 02:27:25
  • Java实现两人五子棋游戏(五) 判断是否有一方胜出

    2022-03-03 18:29:44
  • Servlet中/和/*的区别详解

    2022-07-11 03:21:33
  • 图文详解SpringBoot中Log日志的集成

    2023-05-27 09:55:13
  • Java中常见的查找算法与排序算法总结

    2021-07-14 13:21:23
  • 替换so文件来动态替换Flutter代码实现详解

    2023-06-23 16:24:06
  • 详解Java中的封装、继承、多态

    2022-09-24 06:26:23
  • Android实现拍照、录像、录音代码范例

    2021-08-16 09:31:40
  • C# 递归算法详解

    2021-09-10 19:08:44
  • 详解c# AutoMapper 使用方式

    2022-05-25 20:51:38
  • Android数据传输中的参数加密代码示例

    2021-05-25 23:54:43
  • Android ScrollView 下嵌套 ListView 或 GridView出现问题解决办法

    2023-03-31 07:17:04
  • Android 自定义view仿支付宝咻一咻功能

    2023-06-01 07:42:09
  • C#调用C++DLL传递结构体数组的终极解决方案

    2022-05-31 09:54:30
  • Java设计模式之抽象工厂模式实例详解

    2023-11-29 04:04:57
  • C#中的yield关键字详解

    2023-01-11 08:19:01
  • C# 如何在MVC3中取消备用控制器的选择

    2023-02-16 06:48:18
  • C/C++在Java、Android和Objective-C三大平台下实现混合编程

    2022-01-04 16:58:08
  • asp之家 软件编程 m.aspxhome.com