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)

大家都在看

  • C语言-字符串函数的实现(一)之strlen

    C语言中的字符串函数有如下这些 获取字符串长度 strlen 长度不受限制的字符串函数 strcpy strcat strcmp 长度受限制的字符串函数 strncpy strnc…

    Java 2023年6月10日
    043
  • NC-日志配置及代码详解

    日志目录: /nchome/nclogs/servername/ ,其中servername集群时目录类似为master,ncMem01等。非集群时目录为:server1(服务名)…

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

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

    Java 2023年6月5日
    076
  • Mybatis的缓存

    Mybatis的一级缓存是 默认开启的,你只要搭建一个Mybatis框架,就可以直接使用一级缓存。 一级缓存是 SqlSession级别的,通过SqlSession查询的数据会被缓…

    Java 2023年6月14日
    083
  • Halo 开源项目学习(七):缓存机制

    基本介绍 我们知道,频繁操作数据库会降低服务器的系统性能,因此通常需要将频繁访问、更新的数据存入到缓存。Halo 项目也引入了缓存机制,且设置了多种实现方式,如自定义缓存、Redi…

    Java 2023年6月9日
    064
  • 〖Spring Cloud〗Hystrix:服务熔断

    Hystrix:服务熔断 相关视频教程(来自动力节点):https://www.bilibili.com/video/BV1nK4y1j7gL 服务雪崩 多个微服务之间调用的时候,…

    Java 2023年6月7日
    082
  • SpringCloud : 接入 微信公众号平台(一)、接入微信请求(支持多公众号)

    Feign 版本10.1.0 Spring 版本 5.1.5.RELEASE SpringBoot 版本 2.1.5.RELEASE SpringCloud 版本 2.1.1.RE…

    Java 2023年5月30日
    0113
  • 面试突击69:TCP 可靠吗?为什么?

    相比于 UDP 来说,TCP 的主要特性是三个:有连接、可靠、面向数据流。所谓的”有连接”指的是 TCP 中的连接管理机制,也就是著名的三次握手和四次挥手,…

    Java 2023年5月29日
    077
  • java序列化导致的问题

    问题描述 最近在做一个需求的迭代过程中,遇到了一个tair(公司的一款缓存中间件,类似Redis)反序列化失败的问题,也就是把tair里缓存的值转换成对象的时候报错了。看了一下代码…

    Java 2023年6月13日
    063
  • javaSE 温故而知新

    重温 javaSE 前言:有地基才能有高楼大厦 重温 javaSE 认识java Java基础 1、数据类型 1.1 基本数据类型: 1.2 引用数据类型 1.3 基本数据类型的包…

    Java 2023年6月16日
    068
  • Apache DolphinScheduler新一代分布式工作流任务调度平台实战-上

    概述 定义 特性 名词 模块组成 部署 建议配置 下载 部署规划 前置准备工作 准备启动环境 修改配置文件 初始化数据库 启动 DolphinScheduler 实战使用 监控中心…

    Java 2023年6月5日
    070
  • Java 日志框架概述(slf4j / log4j / JUL / Common-logging(JCL) / logback)

    一、简介 JAVA日志在初期可能官方并没有提供很好且实用的规范,导致各公司或OSS作者选择自行造轮子,这也导致了目前初学者觉得市面上 Java 日志库繁杂的局面。 现在市面流行以 …

    Java 2023年6月6日
    085
  • Linux常用命令

    区分rpm与-qi、-qf、-ql和-qa这4个不同选项组合的作用: rpm -qi 【rpm包名】:查看已安装的RPM包的相关信息。 rpm -qf 【文件的绝对路径】:列出某个…

    Java 2023年6月8日
    079
  • java中的异常(Exception)

    基本概念 *将程序执行中发生的不正常的情况称为”异常”。开发中的语法错误和逻辑错误不是异常 执行过程中的异常事件可分为两大类 错误(Error):Java虚…

    Java 2023年6月6日
    090
  • ShardingSphere-JDBC进行分库分表

    一、前言:分库分表 在大型的互联网系统中,可能单台MySQL的存储容量无法满足业务的需求,这时候就需要进行扩容了。 和之前的问题一样,单台主机的硬件资源是存在瓶颈的,不可能无限制地…

    Java 2023年6月6日
    063
  • Dubbo浅入浅出

    接下来一段时间敖丙将带大家开启紧张刺激的 Dubbo 之旅!是的要开始写 Dubbo 系列的文章了,之前我已经写过一篇架构演进的文章,也说明了微服务的普及化以及重要性,服务化场景下…

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