SpringBoot+Dubbo+ZooKeeper简单案例

1. 创建空的父项目

一直下一步就可以了
在这里插入图片描述

2. 创建生产者服务项目

2.1 provider_service项目目录结构

在这里插入图片描述

2.2 引入依赖

<!--Dubbo-->
<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>2.7.11</version>
</dependency>
<!--zkclient-->
<dependency>
    <groupId>com.github.sgroschupf</groupId>
    <artifactId>zkclient</artifactId>
    <version>0.1</version>
</dependency>

2.3 编写配置文件

application.properties

# 配置开启端口号
server.port=8081

# 配置Dubbo
# 配置Dubbo应用名称
dubbo.application.name=provider_service
# 配置注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
# 配置注册服务(给其他服务调用)
dubbo.scan.base-packages=com.test.service

2.4 编写Service接口

TicketService.java

public interface TicketService {
    public String sellTicket();
}

2.5 编写Service实现类

@Service:指dubbo的注解,可以被扫描到,在项目一启动就自动注册到注册中心;因为spring也有这个注解,避免使用混淆,不推荐使用。
@Component:使用了Dubbo后尽量不要用service注解

@Service//可以被扫描到,在项目一启动就自动注册到注册中心
@Component//使用了Dubbo后尽量不要用service注解
public class TicketServiceImpl implements TicketService {
    @Override
    public String sellTicket() {
        return "provider_service提供ticket";
    }
}

2.6 启动测试

注意:

  1. ZooKeeper服务需要启动成功
  2. dubbo-admin本地jar包也要部署成功
    详情可参考:https://blog.csdn.net/Yearingforthefuture/article/details/117440416
    在浏览器输入:http://localhost:7001/governance/providers 默认用户名、密码都是root
    在这里插入图片描述
    在这里插入图片描述

3. 创建消费者服务项目

3.1 customer_service项目目录结构

在这里插入图片描述

3.2 引入依赖

<!--Dubbo-->
<dependency>
    <groupId>org.apache.dubbo</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>2.7.11</version>
</dependency>
<!--zkclient-->
<dependency>
    <groupId>com.github.sgroschupf</groupId>
    <artifactId>zkclient</artifactId>
    <version>0.1</version>
</dependency>

3.3 编写配置文件

application.properties

server.port=8082

# 配置Dubbo
# 配置Dubbo应用名称
# 消费者取哪里拿服务需要暴露自己的名字
dubbo.application.name=customer_service
# 配置注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181

3.4 编写业务类

@Service:这里使用的是Spring注解,需要注册到容器中
@Reference:引入提供服务类
引入提供服务类不成功解决方案:
1、引用Pom坐标
2、可以定义路径相同的接口名

import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;

@Service //这里使用的是Spring注解,需要注册到容器中
public class UserService {
    //想拿到provider_service提供的票,要去注册中心拿到服务
    @Reference//1、引用Pom坐标2、可以定义路径相同的接口名
    TicketService ticketService;

    public void buyTicket() {
        String ticket = ticketService.sellTicket();
        System.out.println("在注册中心拿到ticket:"+ticket);
    }
}

4. 解决冲突

zookeeper会与springboot的日志发生冲突

<!--zookeeper会与springboot的日志发生冲突-->
<!-- 引入zookeeper -->
<dependency>
    <groupId>org.apache.curator</groupId>
    <artifactId>curator-framework</artifactId>
    <version>2.12.0</version>
</dependency>
<dependency>
    <groupId>org.apache.curator</groupId>
    <artifactId>curator-recipes</artifactId>
    <version>2.12.0</version>
</dependency>
<dependency>
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>3.4.14</version>
    <!--排除这个slf4j-log4j12-->
    <exclusions>
        <exclusion>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
        </exclusion>
    </exclusions>
</dependency>

5. 编写测试类

CustomerServiceApplicationTests.java

@SpringBootTest
class CustomerServiceApplicationTests {

    @Autowired
    UserService userService;
    @Test
    void contextLoads() {
        userService.buyTicket();
    }

}

6. 启动测试

在这里插入图片描述

7. 总结

步骤:

  1. 提供者提供服务
    1.导入依赖
    2.配置注册中心的地址,以及服务发现名,和要扫描的包~
    3.在想要被注册的服务上面~增加一个注解@Service

  2. 消费者如何消费
    1.导入依赖
    ⒉.配置注册中心的地址,配置自己的服务名~
    3.从远程注入服务~

内容参考:https://www.bilibili.com/video/BV1PE411i7CV
仅用于学习!

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值