2019-11-17 yls

创建服务接口模块

接口工程只提供接口,不提供实现,在后面的提供者和消费者中使用

在使用接口的模块中只需要写具体实现类,避免了在每个模块中重复编写接口

  1. 在接口中引入依赖包

            <dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <optional>true</optional>
    </dependency>
  2. 创建一个实体类,一定要实现Serializable接口,否则dubbo协议之间无法传输

    @Data
    @AllArgsConstructor
    public class User implements Serializable {
    private String name;
    }
  3. 创建接口


    public interface UserService {
    List<User> getAll();
    List<User> getAll2();
    }

创建服务提供者

  1. 引入依赖

            <!--引入创建的接口服务-->
    <dependency>
    <groupId>com.yls</groupId>
    <artifactId>common-api</artifactId>
    <version>1.0-SNAPSHOT</version>
    </dependency>
    <!--由于服务提供者不是web项目
    ,只需引入spring-boot-starter,不用引入spring-boot-starter-web-->
    <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    </dependency> <!--dubbo-->
    <dependency>
    <groupId>com.alibaba.boot</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>0.2.0</version>
    </dependency>
  2. 修改配置文件

    #服务名称
    dubbo.application.name=provider1
    #注册中心地址
    dubbo.registry.address=39.97.234.52:2181,39.97.234.52:2182,39.97.234.52:2183
    #注册中心类型
    dubbo.registry.protocol=zookeeper #版本号
    dubbo.application.version=3
    # Dubbo Protocol
    #协议名称
    dubbo.protocol.name=dubbo
    #服务暴露端口
    dubbo.protocol.port=20880
  3. 实现服务接口

    //暴露服务
    //这里的@Service是Dubbo提供的,不是spring中的
    //version必填
    @Service(version = "${dubbo.application.version}")
    @Component
    public class UserImpl implements UserService {
    @Override
    public List<User> getAll() {
    User user1 = new User("张三");
    User user2 = new User("lisi");
    List<User> list = Arrays.asList(user1, user2);
    return list;
    }
    }
  4. 启动服务

    //@EnableDubbo等价于在配置文件中配置dubbo.scan.base-packages
    //扫描实现类所在的包,注册Bean
    @EnableDubbo
    @SpringBootApplication
    public class ProviderApplication { public static void main(String[] args) { SpringApplication.run(ProviderApplication.class,args);
    }
    }

创建消费者

  1. 引入依赖

    <!--消费者是web项目-->
    <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    </dependency> <!--dubbo-->
    <dependency>
    <groupId>com.alibaba.boot</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>0.2.0</version>
    </dependency> <!--引入创建的接口服务-->
    <dependency>
    <groupId>com.yls</groupId>
    <artifactId>common-api</artifactId>
    <version>1.0-SNAPSHOT</version>
    </dependency>
  2. 修改配置文件

    #注册中心
    dubbo.registry.address=39.97.234.52:2181,39.97.234.52:2182,39.97.234.52:2183
    dubbo.registry.protocol=zookeeper
    #dubbo应用名称
    dubbo.application.name=consumer1
  3. 实现消费接口

    //服务消费者的Service是spring的
    @Service
    public class OrderImpl implements OrderService { //使用dubbo提供的@Reference访问远程服务
    //version对应服务提供者的version
    @Reference(version = "3")
    private UserService userService; @Override
    public List<User> init() {
    List<User> list = userService.getAll();
    list.forEach(item -> System.out.println(item.getName()));
    return list;
    }
    }
  4. 创建controller

    @Controller
    public class OrderController { @Autowired
    private OrderService orderService; @ResponseBody
    @RequestMapping("/init")
    public List<User> init() {
    return orderService.init();
    }
    }
  5. 启动服务消费者

    @EnableDubbo
    @SpringBootApplication
    public class ConsumerApplication {
    public static void main(String[] args) {
    SpringApplication.run(ConsumerApplication.class, args);
    }
    }

dubbo相关补充

  1. dubbo使用本地缓存方式,如果注册中心全部宕机,dubbo也能正常工作,就算没有注册中心,dubbo也能通过dubbo直连通信

    //使用dubbo提供的@Reference访问远程服务
    //version对应服务提供者的version
    //url:如果没有注册中心,可以通过url配置服务提供者的dubbo协议端口,进行dubbo直连
    @Reference(version = "3",url ="127.0.0.1:20880" )
    private UserService userService;

springboot使用dubbo和zookeeper的更多相关文章

  1. Springboot整合Dubbo和Zookeeper

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

  2. SpringBoot整合Dubbo配合ZooKeeper注册中心

    安装ZooKeeper 我这里使用zookeeper作为服务注册中心,版本3.4.9,下载地址: http://mirrors.hust.edu.cn/apache/zookeeper/zookeep ...

  3. SpringBoot分布式 - Dubbo+ZooKeeper

    一:介绍 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务.它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护.域名服务.分布式同步.组服务等. Dubbo是Alib ...

  4. springboot整合dubbo\zookeeper做注册中心

    springboot整合dubbo发布服务,zookeeper做注册中心.前期的安装zookeeper以及启动zookeeper集群就不说了. dubbo-admin-2.5.4.war:dubbo服 ...

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

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

  6. SpringBoot(十一) Dubbo分布式与Zookeeper

    Dubbo简介 1.Dubbo简介 1. Dubbo是什么? dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有dubbo这样的分布式服务框架的需求,并且本质上 ...

  7. springboot+mybatis+dubbo+aop日志第一篇

    本篇文章主要讲述项目搭建过程,不会涉及过多的基础知识,本项目是作者对前段时间学习的一个总结,主要使用到技术有:maven父子工程.springboot.mybatis.dubbo.zookeeper. ...

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

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

  9. springboot整合dubbox与zookeeper

    springboot中dubbo依赖的引入和配置(application.properties)参见:https://blog.csdn.net/wohaqiyi/article/details/72 ...

随机推荐

  1. PHP range

    1.函数的作用:生成范围内的数据 2.函数的参数: @param mixed $start @param mixed $end @param mixed $step 3.例子: <?php $n ...

  2. 前端工程师如何理解 TCP/IP 传输层协议?

    网络协议是每个前端工程师都必须要掌握的知识,TCP/IP 中有两个具有代表性的传输层协议,分别是 TCP 和 UDP,本文将介绍下这两者以及它们之间的区别. TCP/IP网络模型 计算机与网络设备要相 ...

  3. iOS开发请您把握现在 — 面向未来学习

    iOS开发请您把握现在 — 面向未来学习 这一篇文章,如果你是一名iOS开发正好也处于开发晋升瓶颈迷茫期,不妨停下你的脚步,花五分钟看看,兴许有你需要的!文章结尾有彩蛋 群里常见的唱哀 iOS现在到底 ...

  4. shell传递参数(三)

    $n:n代表一个数字,指执行脚本的第n个参数.特别地,$0指执行的文件名 [root@ipha-dev71- exercise_shell]# cat test.sh #!/bin/bash echo ...

  5. 『嗨威说』算法设计与分析 - 动态规划思想小结(HDU 4283 You Are the One)

    本文索引目录: 一.动态规划的基本思想 二.数字三角形.最大子段和(PTA)递归方程 三.一道区间动态规划题点拨升华动态规划思想 四.结对编程情况 一.动态规划的基本思想: 1.1 基本概念: 动态规 ...

  6. Spring Boot项目中如何定制PropertyEditors

    本文首发于个人网站:Spring Boot项目中如何定制PropertyEditors 在Spring Boot: 定制HTTP消息转换器一文中我们学习了如何配置消息转换器用于HTTP请求和响应数据, ...

  7. 【Leetcode 做题学算法周刊】第一期

    首发于微信公众号<前端成长记>,写于 2019.10.28 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 1. ...

  8. WebStorm 使用过程中出现的一些问题以及解决方案

    标签: WebStorm 配置 描述: 有关 WebStorm 使用过程中出现的一些问题以及其解决方案的汇总 "unresolved function or method" 问题描 ...

  9. vue 开发插件流程

    UI demo UI 插件汇总 我的github iSAM2016 在练习写UI组件的,用到全局的插件,网上看了些资料.看到些的挺好的,我也顺便总结一下写插件的流程: 声明插件-> 写插件-&g ...

  10. Kerberos kinit crontab定时任务不生效的问题解决

    问题 有这样一个定时任务 1 */12 * * * kinit -kt xxxxxx.keytab principle 这样写每天 12点,执行一次. 但是服务器的应用程序报错: GSS initia ...