SpringBoot-13 Dubbo实战

前提: 已经准备好Dubbo-admin和Zookeeper

前置准备

1.创建项目

显示创建一个Empty Project,创建两个Module--->consumer-server以及provider-server

这是创建成功的结构。

2.导入依赖

两个Module都导入下方依赖:

  1. <!-- dubbo-spring-boot-starter -->
  2. <dependency>
  3. <groupId>org.apache.dubbo</groupId>
  4. <artifactId>dubbo-spring-boot-starter</artifactId>
  5. <version>2.7.8</version>
  6. </dependency>
  7. <!-- zkclient -->
  8. <dependency>
  9. <groupId>com.github.sgroschupf</groupId>
  10. <artifactId>zkclient</artifactId>
  11. <version>0.1</version>
  12. </dependency>
  13. <dependency>
  14. <groupId>org.apache.curator</groupId>
  15. <artifactId>curator-framework</artifactId>
  16. <version>2.12.0</version>
  17. </dependency>
  18. <dependency>
  19. <groupId>org.apache.curator</groupId>
  20. <artifactId>curator-recipes</artifactId>
  21. <version>2.12.0</version>
  22. </dependency>
  23. <dependency>
  24. <groupId>org.apache.zookeeper</groupId>
  25. <artifactId>zookeeper</artifactId>
  26. <version>3.4.14</version>
  27. <exclusions>
  28. <exclusion>
  29. <groupId>org.slf4j</groupId>
  30. <artifactId>slf4j-log4j12</artifactId>
  31. </exclusion>
  32. </exclusions>
  33. </dependency>

搭建项目

1.提供者

1.1 Service层

创建一个Service文件夹:

  1. public interface TicketService {
  2. public String getTicket();
  3. }
  1. @Service
  2. @Component
  3. public class TicketServiceImpl implements TicketService {
  4. @Override
  5. public String getTicket() {
  6. return "这是一个getTicket()";
  7. }
  8. }

注意:

这里的@Component是Spring下的注解,但是@Service应该使用的是Dubbo下的注解

用了Dubbo尽量不要用@Service,如果要使用,记得分清楚Spring和Dubbo注解的不同

1.2 配置信息

  1. server.port=8001
  2. # 服务应用名字
  3. dubbo.application.name=provider-server
  4. # 注册中心地址
  5. dubbo.registry.address=zookeeper://127.0.0.1:2181
  6. # 注册服务
  7. dubbo.scan.base-packages=com.zc.Service

1.3 查看Dubbo的消费者

  • 打开Zookeeper的服务器
  • 运行Dubbo-admin打包的jar包
  1. java -jar xxxx.jar
  • 运行消费者Module

2.消费者

2.1 Service层

  1. @Service
  2. public class UserService {
  3. //想拿到 提供者 提供的东西,要去注册中心拿
  4. @Reference //引用
  5. TicketService ticketService;
  6. public void buyTicket(){
  7. String ticket = ticketService.getTicket();
  8. System.out.println("拿到啦---"+ticket);
  9. }
  10. }
  • 这里的@Service是将该类注入到Spring容器,使用的Spring的注解

  • 这里 TicketService ticketService; 会报错,因为在 consumer-server 中没有 TicketService 这个接口。

所以,我们把这个接口复制过来:

  1. public interface TicketService {
  2. public String getTicket();
  3. }

这样就可以使用了,Dubbo会自动给你引用提供者的实现类。

2.2 配置信息

  1. server.port=8002
  2. # 消费者拿服务路径
  3. dubbo.application.name=consumer-server
  4. # 注册中心的地址
  5. dubbo.registry.address=zookeeper://127.0.0.1:2181

消费者与提供者的不同:

提供者配置信息不需要注册服务,消费者提供地址,消费者只需要拿到服务。

3.运行测试

consumer-server中的test中进行测试:

  1. @SpringBootTest
  2. class ConsumerServerApplicationTests {
  3. @Autowired
  4. UserService userService;
  5. @Test
  6. void contextLoads() {
  7. userService.buyTicket();
  8. }
  9. }

小结

前提:Zookeeper已经开启

  1. 提供者提供服务

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

    1. 导入依赖
    2. 配置注册中心的地址,配置自己的服务名-
    3. 从远程注入服务1

个人博客为:

MoYu's HomePage

MoYu's Gitee Blog

SpringBoot-13 Dubbo实战的更多相关文章

  1. dubbo实战之二:与SpringBoot集成

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  2. dubbo实战之三:使用Zookeeper注册中心

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  3. dubbo实战之四:管理控制台dubbo-admin

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  4. Jmeter实时监控+SpringBoot接口性能实战

    性能测试 Jmeter实时监控+SpringBoot接口性能实战 自动化 SpringBoot Java Jmeter实时监控+SpringBoot接口性能实战 一.实验目的及实验环境 1.1.实验目 ...

  5. Springboot整合Dubbo和Zookeeper

    Dubbo是一款由阿里巴巴开发的远程服务调用框架(RPC),其可以透明化的调用远程服务,就像调用本地服务一样简单.截至目前,Dubbo发布了基于Spring Boot构建的版本,版本号为0.2.0,这 ...

  6. springboot整合dubbo+zookeeper最新详细

    引入 最近和小伙伴做一个比赛,处于开发阶段,因为涉及的服务比较多,且服务需要分开部署在不同的服务器上,讨论之后,打算采用分布式来做,之前学习springboot的时候,部分章节涉及到了springbo ...

  7. dubbo实战之一:准备和初体验

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  8. [.net 面向对象程序设计深入](13)实战设计模式——设计模式使用场景及原则

    [.net 面向对象程序设计深入](13)实战设计模式——设计模式使用场景及原则 1,什么是设计模式? 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计 ...

  9. IDEA上创建 Maven SpringBoot + zookeeper +dubbo 实例

    概述 首先声明,本文是学习总结类型的博客内容,如有雷同纯属学习.本位主要结合zookeeper和dubbo做个简单实例.目前来说,一般网站架构随着业务的发展,逻辑越来越复杂,数据量越来越大,交互越来越 ...

  10. 基于springboot构建dubbo的入门demo

    之前记录了构建dubbo入门demo所需的环境以及基于普通maven项目构建dubbo的入门案例,今天记录在这些的基础上基于springboot来构建dubbo的入门demo:众所周知,springb ...

随机推荐

  1. css picture

    css picture https://github.com/cyanharlow https://diana-adrianne.com/ demo https://github.com/cyanha ...

  2. 用Qt写了个将视频设置为壁纸的软件

    软件功能很简单,使用时占用的资源和播放的视频有关: 依赖于FFplay,Github源码 效果图:

  3. Flutter 创建dashboard页面

    1 import 'package:flutter/material.dart'; void main() => runApp(MyApp()); class MyApp extends Sta ...

  4. 「NGK每日快讯」12.2日NGK公链第29期官方快讯!

  5. 适合Linux嵌入式项目的代码构建与依赖管理工具——cazel

    前言 我们知道,现在有很多流行的优秀代码构建工具,如CMake.jetkins.bazel等.这些不同的构建工具在其应用的领域起到了举足轻重的作用. 但是,如果仔细研究就会发现,在嵌入式领域,构建工具 ...

  6. LeetCode-[list-of-depth-lcci]

    特定深度节点链表-求解每一层二叉树从左到右遍历形成的链表 list-of-depth-lcci 这是关于二叉树的问题,遍历每一层的结点并且存在链表中. 可以采取队列类似于广度优先搜索的方法进行搜索.每 ...

  7. Hadoop的常用命令

    注:hadoop的使用命令包含 hadoop fs 开头 or hdfs dfs开头 等多种形式来操作. 这里以hadoo fs的形式来介绍在这些命令 1.列出根目录下所有的目录或文件 hadoop ...

  8. MacOS如何调整JD-GUI反编译工具字体大小

    how to change the fontsize of JD-GUI in MacOS? MacOS如何调整JD-GUI反编译工具字体大小? 问题描述 JD-GUI是一款比较好用的反编译工具,不小 ...

  9. Node.js 模块化你所需要知道的事

    一.前言 我们知道,Node.js是基于CommonJS规范进行模块化管理的,模块化是面对复杂的业务场景不可或缺的工具,或许你经常使用它,但却从没有系统的了解过,所以今天我们来聊一聊Node.js模块 ...

  10. Hi3559AV100 NNIE开发(4)mobilefacenet.cfg参数配置挖坑解决与SVP_NNIE_Cnn实现分析

    前面随笔给出了NNIE开发的基本知识,下面几篇随笔将着重于Mobilefacenet NNIE开发,实现mobilefacenet.wk的chip版本,并在Hi3559AV100上实现mobilefa ...