Dubbo实战教程

“Dubbo是阿里巴巴开源的基于 Java 的高性能 RPC(一种远程调用) 分布式服务框架(SOA),致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。”
RPC翻译过来叫做 远程过程调用(Remote Process Call),我们为什么需要RPC框架?
HTTP了解过吧,平常我们的Web项目,从网页向服务端发起请求,用的就是HTTP协议
当然,服务端和服务端之间也可以通过HTTP来进行交互,不过HTTP底层是使用TCP进行传输(三次握手,四次挥手),对服务来说:”太重了”,服务和服务之间的调用不需要例如HTTP的一些东西,比如:

HTTP/1.0 200 OK
Content-Type: text/plain
Content-Length: 137521
Expires: Thu, 05 Dec 2019 16:00:00 GMT
Last-Modified: Wed, 5 August 2019 15:55:28 GMT
Server: Apache 0.84

 Hello xdclass

所以,RPC诞生了,它是专为分布式而生,是一个轻量级的”HTTP”,同时为分布式服务提供”负载均衡””服务发现””熔断降级”等功能
PS:很多同学不想学新技术的很大一个原因在于:不知道怎么学起,官方文档太多,看着太枯燥,B站大学内容丰富,但动则几百个小时,让人失去耐心,大家都想速成,迅速掌握一个知识点或者一门技术。在这里我和大家分享一个skill,我自己学习的方法是:先广,而深;先用,再精。
先广而深,其实就是一个量变到质变的过程,先广泛的用,不管什么技术,我自己先实战一遍,既然这门技术是趋势,我就先学,底层什么原理都不管,会用就行。
先用后精,当你已经能够熟练使用一门技术的时候,你就应该去探索它的底层实现了,因为使用的门槛低啊,而且之前积累了那么多知识后,再去了解它的底层实现,自然水到渠成,因为大道至简,很多东西都是相通的。
好了,不多BB,看下实战吧。

1、创建工程 demo-dubbo-parent

为了方便,就不创多个工程了,使用多模块的开发。

1.1创建一个Maven项目

Dubbo实战教程

1.2.引入依赖

这是完整的 pom.xml文件,可以直接复制过去


    4.0.0

    org.xiaofengstu
    demo-dubbo-parent
    pom
    1.0-SNAPSHOT

        spring-boot-starter-parent
        org.springframework.boot
        2.3.5.RELEASE

        11
        11

                org.springframework.boot
                spring-boot-starter
                2.3.7.RELEASE

                org.springframework.boot
                spring-boot-starter-web
                2.3.7.RELEASE

                org.apache.dubbo
                dubbo-spring-boot-starter
                3.0.8

                org.apache.curator
                curator-recipes
                5.2.1

                org.apache.curator
                curator-framework
                5.2.1

                org.apache.curator
                curator-x-discovery
                5.2.1

2、创建 api 模块

这里爆红是因为我之前创过一次,所以大家创建的时候是没有问题的

Dubbo实战教程
这个 module 不需要引入依赖,只需要写一个接口就行
Dubbo实战教程

3、创建 provider 模块

方法和创建 api module 一样,不过 pom.xml 需要改动

3.1.引入依赖


        demo-dubbo-parent
        org.xiaofengstu
        1.0-SNAPSHOT

    4.0.0

    provider

        11
        11

            api
            org.xiaofengstu
            1.0-SNAPSHOT

                org.springframework.boot
                spring-boot-starter

                org.apache.dubbo
                dubbo-spring-boot-starter

                org.apache.curator
                curator-recipes

                org.apache.curator
                curator-framework
                5.2.1

            org.apache.curator
            curator-x-discovery
            5.2.1

这也是完整的 pom.xml 文件,可以直接拷贝,这里把 api module 打包进来了,一会儿需要写个子类去实现刚刚在 api module 中写的接口。

package com.xiaofengstu.dubbo.service;

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

/**
 * @Author FengZeng
 * @Date 2022-06-19 20:37
 * @Description TODO
 */
@DubboService
public class DemoDubboServiceImpl implements DemoDubboService {

  @Override
  public String demo(String param) {
    System.out.println("provider的demo方法被调用。。。");
    return param + "123";
  }

}

还需要写一个启动类,因为是Springboot项目嘛

package com.xiaofengstu.dubbo;

import org.apache.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * @Author FengZeng
 * @Date 2022-06-19 20:44
 * @Description TODO
 */
@SpringBootApplication
@EnableDubbo
public class ProviderApplication {
  public static void main(String[] args) {
    SpringApplication.run(ProviderApplication.class);
  }
}

3.2.配置文件

dubbo:
  application:
    name: dubbo-provider
  registry:
    address: zookeeper://127.0.0.1:2181
  protocol:
    name: dubbo
    port: 20881

provider module 目录结构如下:

Dubbo实战教程

4、创建 consumer 模块

4.1.引入依赖


        demo-dubbo-parent
        org.xiaofengstu
        1.0-SNAPSHOT

    4.0.0

    comsumer

        11
        11

            api
            org.xiaofengstu
            1.0-SNAPSHOT

            org.springframework.boot
            spring-boot-starter

            org.springframework.boot
            spring-boot-starter-web

            org.apache.dubbo
            dubbo-spring-boot-starter

            org.apache.curator
            curator-recipes

            org.apache.curator
            curator-framework
            5.2.1

            org.apache.curator
            curator-x-discovery
            5.2.1

4.1.创建 service

package com.xiaofengstu.service;

/**
 * @Author FengZeng
 * @Date 2022-06-19 20:50
 * @Description TODO
 */
public interface DemoService {
  public String demo();
}

实现类:

package com.xiaofengstu.service.impl;

import com.xiaofengstu.dubbo.service.DemoDubboService;
import com.xiaofengstu.service.DemoService;
import org.apache.dubbo.config.annotation.DubboReference;
import org.apache.dubbo.config.annotation.DubboService;
import org.springframework.stereotype.Service;

/**
 * @Author FengZeng
 * @Date 2022-06-19 20:51
 * @Description TODO
 */
@DubboService
@Service
public class DemoServiceImpl implements DemoService {

  @DubboReference(loadbalance = "RoundRobin")
  private DemoDubboService demoDubboService;

  @Override
  public String demo() {

    return demoDubboService.demo("张三丰");
  }
}

写一个Controoler 对外进行访问:

package com.xiaofengstu.controller;

import com.xiaofengstu.service.DemoService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Author FengZeng
 * @Date 2022-06-19 20:56
 * @Description TODO
 */
@RestController
public class DemoController {

  @Autowired
  private DemoService demoService;

  @RequestMapping("/demo")
  public String demo() {
    System.out.println("开始远程调用。。。");
    return demoService.demo();
  }
}

4.2.配置文件

dubbo:
  application:
    name: dubbo-consumer
  registry:
    address: zookeeper://127.0.0.1:2181

consumer module 的目录结构如下:

Dubbo实战教程

5、启动项目

dubbo 需要注册中心,官方推荐的是 zookeeper,所以还需要启一个 zookeeper
如果图方便,可以参考我使用 docker 部署 zk 服务,传送门

  1. 启动 provider module
  2. 启动 consumer module
  3. 访问 localhost:8080/demo

控制台输出:

Dubbo实战教程
Dubbo实战教程
到此,我们已经完整的实现了一次 dubbo 的rpc 调用。

6、dubbo的注解

因为是使用的 Springboot项目,所以需要在启动类上添加 @EnableDubbo注解。
Dubbo 被调用的服务需要加上 @DubboService注解
注意Dubbo的服务需要加上 @DubboReference注解
同时,这些注解也是会被 Spring 进行管理的,原因在 @EnableDubbo上。
源码我放在 gitee 上了,不清楚的同学可以下载下来学习。gitee地址

Original: https://www.cnblogs.com/Fzeng/p/16393290.html
Author: 小冯同学c
Title: Dubbo实战教程

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/592959/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • HTML笔记整理–下节

    欢迎来到HTML基础笔记下节部分! 内联样式 当特殊的样式需要应用到个别元素时,就可以使用内联样式。 使用内联样式的方法是在相关的标签中使用样式属性。样式属性可以包含任何 CSS …

    Java 2023年6月7日
    098
  • Android照相机应用

    Android在设计架构的时候,采用了mashup(混搭)的设计理念,也就是说一切都是组建,自己写的是组件,别人提供的也是组件,使用的时候只要符合相关协议就可以把他们当作自己的组件…

    Java 2023年6月7日
    081
  • Jenkins构建vue项目自动部署到远程服务器

    1.环境要求 以下服务器的操作系统均为Centos7 服务器A:Gitlab 服务器B:Jenkins 服务器C:Nginx,即你的vue项目部署服务器。 gitlab、Jenki…

    Java 2023年6月5日
    085
  • 基于开源方案构建统一的文件在线预览与office协同编辑平台的架构与实现历程

    大家好,又见面了。 在构建业务系统的时候,经常会涉及到对附件的支持,继而又会引申出对附件 在线预&#x89…

    Java 2023年6月7日
    0100
  • SpringBoot使用Redis教程(共5步)

    SpringBoot使用Redis教程 应用环境: 存&#x6…

    Java 2023年6月16日
    090
  • 为Windows Service 2019 使用 Docker

    引言最近收到领导通知,甲方需要将原来的服务器迁移到新的服务器。原来的服务器上安装了很多的服务,每次重启之后总是有很多的问题需要人工大量的进行干预。这次迁移的还是Windows服务器…

    Java 2023年6月15日
    077
  • springboot整合JPA

    spring-data-jpa:就是和数据库打交道,进行数据访问的。 一:步骤: 1.新建一个maven项目,新建一个数据库(数据库中可以没有表) 2.导入相关依赖 3.编写app…

    Java 2023年6月9日
    078
  • LeetCode剑指Offer刷题总结(一)

    LeetCode过程中值得反思的细节 以下题号均指LeetCode剑指offer题库中的题号 本文章将每周定期更新,当内容达到10题左右时将会开下一节。 二维数组越界问题04 pu…

    Java 2023年6月7日
    075
  • java 导出excel示例(easyExcel)

    1.情景展示 在javaweb项目当中,如何将数据导入excel,并将生成的excel文件返回给前端? 2.具体分析 可通过阿里巴巴的easyExcel来实现。 所需jar包 &l…

    Java 2023年5月29日
    084
  • 60.摄影师

    dsfds posted @2022-09-28 08:34 随遇而安== 阅读(4 ) 评论() 编辑 Original: https://www.cnblogs.com/55z…

    Java 2023年6月7日
    059
  • SpringCloud+Alibaba微服务教程,Java自学/进阶程序员必看

    正文 Spring Cloud是目前市面上最火爆的Java微服务技术栈,因其功能丰富涉及微服务管理全面,并且在高可靠、高可阔以及在应对复杂业务和承受并发的能力上发挥出色,使其受到众…

    Java 2023年6月9日
    082
  • 拿捏!隔离级别、幻读、Gap Lock、Next-Key Lock

    前面我写了很多Mysql相关的知识点,到这一篇稍微可以串一下了,从SQL执行流程、MVCC到锁,很多时候可能觉得对于间隙锁和Next-Key Lock好像已经理解了,但是好像又觉得…

    Java 2023年6月13日
    081
  • windows安装jdk8

    win10系统安装jdk8全过程 一 下载安装文件 jdk的安装与配置是Java学习的第一步,下面记录一下具体过程。首先根据自己系统下载对应版本。下载地址http://www.or…

    Java 2023年5月30日
    072
  • 多元线性回归 C++实现

    https://www.pudn.com/detail/6011226 Original: https://www.cnblogs.com/lostO/p/16699839.htm…

    Java 2023年6月16日
    070
  • 原来你是这样的JAVA[05]–String

    1.从概念上讲,java字符串就是Unicode字符串。2.字符串拼接用指定分隔符拼接字符串数组时,使用StringJoiner或者String.join()更方便;用String…

    Java 2023年5月29日
    0112
  • linux中find命令的摘要

    find命令的使用 按照时间查找 可以很方便按照时间查找文件 find -[mtime|atime|ctime] n #查找n天前当天[修改|访问|创建]的文件 find -[mt…

    Java 2023年6月7日
    089
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球