SpringBoot+Dubbo+Zookeeper实现分布式系统步骤


一、分布式系统通俗解释

场景比喻:想象一个大型超市(分布式系统):

  • 收银台(服务消费者):处理顾客请求
  • 仓库(服务提供者):提供商品
  • 总控室(Zookeeper):记录哪个仓库有什么商品
  • 物流系统(Dubbo):负责收银台和仓库之间的通信

当顾客要买可乐时:

  1. 收银台询问总控室:哪里能拿到可乐?
  2. 总控室返回仓库A的地址
  3. 收银台通过物流系统向仓库A请求可乐
  4. 仓库A将可乐送到收银台

二、环境准备(详细版)

1. 软件版本

2. 安装Zookeeper(单机模式)

# 解压后进入conf目录
cp zoo_sample.cfg zoo.cfg
# 修改配置(关键部分)
dataDir=/tmp/zookeeper
clientPort=2181

# 启动服务(Linux/Mac)
bin/zkServer.sh start
# Windows双击zkServer.cmd

三、完整项目结构(带详细注释)

distributed-demo
├── api           # 服务接口定义
├── provider      # 服务提供者
└── consumer      # 服务消费者

四、手把手代码实现

步骤1:创建父工程(管理依赖)

<!-- pom.xml -->
<project>
    <groupId>com.example</groupId>
    <artifactId>distributed-demo</artifactId>
    <version>1.0</version>
    <packaging>pom</packaging>
    
    <modules>
        <module>api</module>
        <module>provider</module>
        <module>consumer</module>
    </modules>

    <properties>
        <dubbo.version>2.7.15</dubbo.version>
        <zk.version>3.7.0</zk.version>
    </properties>

    <dependencies>
        <!-- Dubbo核心 -->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>${dubbo.version}</version>
        </dependency>
        
        <!-- Zookeeper客户端 -->
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>5.1.0</version>
        </dependency>
    </dependencies>
</project>

步骤2:API模块(定义服务契约)

// api/src/main/java/com/example/api/CalculatorService.java
public interface CalculatorService {
   
   
    /**
     * 加法服务
     * @param a 加数
     * @param b 被加数
     * @return 和
     */
    
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员buddha2080

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值