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)

大家都在看

  • 《二十三种设计模式》通俗的创建型之单例设计模式

    单例模式(Singleton Pattern)是Java中 最简单的设计模式之一。 这种模式涉及到一个 单一的类,该类负责创建自己的对象,同时确保只有 单个对象被创建。这个类提供了…

    Java 2023年6月7日
    0108
  • 事务的隔离级别详解

    四种隔离级别: READ-UNCOMMITTED(读取未提交): 最低的隔离级别,允许读取尚未提交的数据变更, 可能会导致脏读、幻读或不可重复读 。 READ-COMMITTED(…

    Java 2023年6月5日
    097
  • spring框架技术方面

    一:描述spring事务的只读,超时,回滚的原则。1.spring事务的只读:“只读事务”并不是一个强制选项,它只是一个暗示,提示数据库驱动程序和数据库系统…

    Java 2023年6月5日
    078
  • rocketmq 如何保证顺序消费

    rocketMQ 为了保证 consumer 顺序消费,做了很多工作。 MQClientManager 在 jvm 进程中是单例,其内部维护一个 map,键是 clientId,值…

    Java 2023年5月30日
    060
  • 浏览器地址栏从输入地址到页面展示都发生了什么

    1 URL输入 2 DNS解析 浏览器会首先从缓存中找是否存在域名,如果存在就直接取出对应的ip地址, 其中会请求 第二步,本地系统缓存 如果浏览器缓存没找到,就检查本地操作系统的…

    Java 2023年6月6日
    089
  • 验证码和前台数据处理结果

    验证码和前台数据处理结果 RegistUserServlet类: @WebServlet("/registUserServlet") public class …

    Java 2023年6月6日
    074
  • 使用springboot创建web项目,并使用外部Tomcat

    在springboot中默认使用的是嵌入式的servlet容器,我们可以不用引入外部Tomcat就可以运行程序。这样的嵌入式容器优点就是简单、便携,但是缺点也比较明显,比如他默认不…

    Java 2023年5月30日
    085
  • java jfreechart 时序图横坐标显示,设置步数初始坐标不展示问题解决

    1,选择框架 org.jfree jfreechart 1.5.2 2,问题 我们时间绘制走势图的时候,框架会自动计算间隔,并在横坐标显示出计算之后的日期 但是往往自动计算出来展示…

    Java 2023年5月29日
    075
  • Springboot启动后执行方法(4种)

    一、注解@PostConstruct 使用注解@PostConstruct是最常见的一种方式,存在的问题是如果执行的方法耗时过长,会导致项目在方法执行期间无法提供服务。 二、Com…

    Java 2023年5月30日
    066
  • 我的大一总结

    图片不太清楚这里附上链接密码: w98f https://udld.github.io/ (老师总结)大一内容总结 编程语言初级使用 C,java (python 未完成) Lin…

    Java 2023年6月5日
    082
  • AVL树到底是什么?

    一. 什么是AVL树 在认识AVL树之前我们先认识一下什么是二叉搜索树: 1.二叉搜索树 二叉搜索树又称为二叉排序树,二叉搜索树满足所有的左孩子节点都小于其根节点的值,所有的右孩子…

    Java 2023年5月29日
    078
  • CentOS7下FTP的安装与配置1(有些机器安装有问题,用问题请使用第二篇)

    1、安装vsftpd 2、编辑ftp配置文件 做如下修改: 编辑vsftpd.conf,最后面增加下面这段,节省逆向解析时间,可以增加速度 3、设置开机启动ftp 4、重新启动ft…

    Java 2023年5月29日
    0101
  • 创建对象时类的调用顺序

    代码块 1.创建一个对象时,在一个类中调用的顺序是: 1.调用静态代码块和静态属性初始化(优先级相同,如果有多个,则按他们定义的顺序调用) 2.调用普通代码块和普通属性的初始化(优…

    Java 2023年6月5日
    082
  • Nginx 通过 /api 前缀和二级域名进行反向代理

    当我们在一台服务器上 启动多个服务时, 因为在 http 协议下默认端口是 80 端口, https 下默认是 443 端口,为了好记和美观我们 只能对外暴漏这两个端口。 以 ht…

    Java 2023年5月30日
    092
  • knn算法详解

    1.什么是knn算法 俗话说:物以类聚,人以群分。看一个人什么样,看他身边的朋友什么样就知道了(这里并没歧视谁,只是大概率是这样) 对于判断下图绿色的球是哪种数据类型的方法就是根据…

    Java 2023年6月13日
    0134
  • @RequestParam,@RequestBody,@ResponseBody,@PathVariable注解的一点小总结

    一、前提知识: http协议规定一次请求对应一次响应,根据不同的请求方式,请求的内容会有所不同; 发送GET请求是没有请求体的,参数会直接拼接保留到url后一并发送; 而POST请…

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