Dubbo + ZK + SpringBoot 分布式实战

Dubbo 的官网:https://dubbo.apache.org/zh/

项目结构

  • dubbo-demo 作为外层父项目。
  • dubbo-api:作为公共模块,暴露接口,服务提供者与服务生产者模块依赖于它;
  • dubbo-provider:服务提供者,用于实现接口;
  • dubbo-consumer:服务消费者,用于调用远程接口;
    在这里插入图片描述

需求:dubbo-consumer 想调用 dubbo-provider 实现的接口方法,但它们位于不同的项目中;

对于这种远程接口调用,可借助 Dubbo 这一 RPC 框架来实现,同时采用 zookeeper 作为注册中心来管理服务;

环境构建

在 dubbo-api 中,引入 dubbo 整合 SpringBoot 的依赖:

        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.3</version>
        </dependency>

再引入 dubbo 整合 zookeeper 的依赖:

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

dubbo-provider 与 dubbo-consumer 中分别引入 dubbo-api 的坐标:

        <dependency>
            <artifactId>dubbo-api</artifactId>
            <groupId>com.study</groupId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

简单 Demo

dubbo-api 中提供 UserService 接口:

package com.study.api;

public interface UserService {
    User queryUserById(Integer id);
}

注意,User 要实现序列化接口,因为 RPC 调用中涉及到序列化传输:

package com.study.api;
import java.io.Serializable;

public class User implements Serializable {
    private Integer id;
    private String name;
    // 省略构造,get/set,toString()

dubbo-provider 中实现 UserService 接口的方法:

package com.study.provider;
import com.study.api.User;
import com.study.api.UserService;
import org.apache.dubbo.config.annotation.Service;

@Service(version = "1.0")
public class UserServiceImpl implements UserService {
    @Override
    public User queryUserById(Integer id) {
        User user = new User(id, "study");
        return user;
    }
}

注意这里采用的是 dubbo 提供的 @Service 注解,暴露服务,version 参数指定版本信息;

dubbo-consumer 中调用该接口方法:

package com.study.consumer;
import com.study.api.UserService;
import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;

@Component
public class UserTest {
    @Reference(version = "1.0")
    private UserService userService;
    @PostConstruct
    public void test() {
        System.out.println(userService.queryUserById(666));
    }
}

注意这里采用的是 dubbo 提供的 @Reference 注解,且 version 值需与前面 Service 中的一致,这样就能自动去注册中心查找所需服务;@PostConstruct 注解能在 Spring 程序启动时自动调用其修饰的方法;

Dubbo 核心配置

dubbo-provider 服务提供者的配置文件:

server:
  port: 8001                              # 指定启动端口,防止冲突

dubbo:
  application:
    name: provider
  registry:
    address: zookeeper://localhost:2181   # 绑定的注册中心地址,采用 ZK,默认端口为 2181
    timeout: 6000                         # 超时时间,单位 ms
  metadata-report:
    address: zookeeper://localhost:2181   # 元中心地址
  protocol:
    name: dubbo                           # 协议名称为 dubbo
    port: 20880                           # 协议端口为 20880
  scan:
    base-packages: com.study.provider     # 扫描服务包所在的位置

dubbo-consumer 中服务消费者的配置文件:

server:
  port: 8002                              # 指定启动端口,防止冲突

dubbo:
  application:
    name: consumer
  registry:
    address: zookeeper://localhost:2181   # 绑定的注册中心地址,采用 ZK,默认端口为 2181

安装启动 Zookeeper

  • Zookeeper 下载地址:https://archive.apache.org/dist/zookeeper/
  • 解压后先进入 conf 目录,将 zoo_sample.cfg 复制一份,改名为 zoo.cfg
  • 可在 zookeeper 外层目录下新建 data 目录,然后在 zoo.cfg 中,将 dataDir 的属性值修改为 …/data;
  • 最后进入到 bin 目录,双击 zkServer.cmd 启动 Zookeeper;

Demo 运行

先启动 dubbo-provider,再启动 dubbo-consumer,运行结果中输出调用接口的返回值。
在这里插入图片描述

总结

  • 在分布式架构中,不同的服务可能位于不同的服务器上,也就不能像传统单体架构那样直接调用。
  • 对于这种异地的调用,采用的是 RPC 调用(远程过程调用)。而 Dubbo 是一个高性能的 RPC 框架,能够为我们解决分布式系统中不同服务之间的通信调用问题等。
  • 对于众多服务的管理,需要引入注册中心。在 Dubbo 中,一般采用 Zookeeper 作为配置中心。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
手把手视频详细讲解项目开发全过程,需要的小伙伴自行百度网盘下载,链接见附件,永久有效。 1、课程简介 Zookeeper是一个开源分布式应用程序协调服务。提供分布式数据一致性解决方案,分布式应用程序可以实现数据发布订阅、负载均衡、命名服务、集群管理分布式锁、分布式队列等功能。在大数据、分布式系统或架构中占有很重要的协调位置。 Dubbo是一款高性能、轻量级的开源Java RPC框架,提供面向接口代理的高性能RPC调用、智能负载均衡、服务自动注册和发现、运行期流量调度、可视化服务治理和运维等功能。 本套课程中,第一阶段深入Zookeeper原理和源码,分析Zookeeper的核心实现,并通过多个应用场景说明,体现出其重要性和广泛的应用性。第二阶段深入Dubbo RPC、SPI等核心功能点,列举多个示例加以应用说明,期望能够帮助学者快速提升Dobbo和Zookeeper的技术能力。 2、适应人群 有一定的Java Web基础。 3、课程亮点 系统的学习Dubbo技术栈,掌握Dubbo、Zookeeper架构原理及应用。 lZookeeper 分布式CAP原则 2PC、3PC Paxos、ZAB ZK单机&集群 快速入门 源码解析 场景应用 分布式锁、队列 1Dubbo RPC核心 RPC实现 容错&治理 IO模型&Dubbo架构 源码解析 4、主讲内容 章节一:Zookeeper 1.分布式概述 2.ZK概述 3.分布式CAP 4.一致性实现 5.ZK单机&集群搭建 6.ZK快速入门 7.ZK源码解析 8.ZK应用场景 9.分布式锁和队列 章节二:Dubbo 1.RPC核心 2.手写RPC 3.Dubbo高可用 4.Dubbo IO模型 5.Dubbo架构 6.源码解析

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值