SpringBoot+Dubbo+Zookeeper实现简单分布式开发的应用详解

 更新时间:2021年12月29日 09:48:08   作者:落叶之枫✓  
这篇文章主要介绍了SpringBoot+Dubbo+Zookeeper实现简单分布式开发的应用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

开始接触分布式概念,学习之前要准备搭建Dubbo和Zookeeper环境的简单搭建。

Window下安装Zookeeper和Dubbo-admin

1、Apache官网下载Zookeeper

点击官网地址下载最新版

下载完成后,打开apache-zookeeper-3.6.2-bin\bin下zkServer.cmd,正常第一次都会闪退的,因为没有配置好zoo.cfg配置文件。

将conf目录下的zoo_sample.cfg文件,复制一份,重命名为zoo.cfg

在这里插入图片描述

在apache-zookeeper-3.6.2-bin目录下新建两个文件夹data和log

在这里插入图片描述

修改zoo.cfg配置文件

修改路径和增加一个

(修改dataDir的路径和增加dataLogDir分别对应刚刚新建的data和log文件夹)

然后运行bin下zkServer.cmd(不关闭)

再运行zkCli.cmd

在这里插入图片描述

证明zookeeper搭建成功(详细的安装步骤百度一大堆)

2、GitHub下载Dubbo-admin

去GitHub里面下载:点击GitHub地址

下载完解压到自己习惯的位置

打开到根目录,本地地址前面加cmd 进入控制台,运行代码,打包dubbo-admin

mvn clean package -Dmaven.test.skip=true

命令行运行 dubbo-admin\target 下的dubbo-admin-0.0.1-SNAPSHOT.jar

java -jar dubbo-admin-0.0.1-SNAPSHOT.jar

执行完毕,我们去访问一下 http://localhost:7001/ , 这时候我们需要输入登录账户和密码,我们都是默认的root-root;

登录成功后,查看界面

在这里插入图片描述

3、SpringBoot + Dubbo + Zookeeper

框架搭建

  • 启动zookeeper !
  • IDEA创建一个空项目,项目选择最下面那个Empty Project;
  • 创建一个模块,选择Spring Initializr,实现服务提供者:provider-server ,选择web依赖即可
  • 创建一个模块,选择Spring Initializr,实现服务消费者:consumer-service,选择web依赖即可

项目创建完毕;

在这里插入图片描述

pom.xml配置文件引入Dubbo + zookeeper

<!-- Dubbo Spring Boot Starter -->
    <dependency>
      <groupId>org.apache.dubbo</groupId>
      <artifactId>dubbo-spring-boot-starter</artifactId>
      <version>2.7.3</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
    <dependency>
      <groupId>com.github.sgroschupf</groupId>
      <artifactId>zkclient</artifactId>
      <version>0.1</version>
    </dependency>

    <!-- 引入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>

在provider-server项目下写一个服务

在这里插入图片描述

TicketService.java

public interface TicketService {

  public String getTicket();
}

TicketServiceImpl.java

import org.apache.dubbo.config.annotation.Service;
import org.springframework.stereotype.Component;

//zookeeper:服务注册与实现

@Service  //可以被扫描到,在项目一启动就自动注册到注册中心
@Component //使用了dubbo后,注意不要用到spring的service注解
public class TicketServiceImpl implements TicketService {
  @Override
  public String getTicket() {
    return "枫";
  }
}

在consumer-server项目下写一个消费者服务

在这里插入图片描述

UserService.Java

import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;


@Service// 注入容器中,用spring的注解
public class UserService {

  //要拿到provider-service提供的票,要去注册中心
  @Reference  //引用,导入dubbo的包。正常开发引用pom坐标,但是可以定义路径相同的接口名
  TicketService ticketService;

  public void buyTicket(){
    String ticket = ticketService.getTicket();

    System.out.println("在注册中心拿到=》"+ticket);
  }
}

在provider-service的配置文件中配置dubbo相关属性!

在这里插入图片描述

11. 在consumer-service的配置文件中配置dubbo相关属性!

在这里插入图片描述

12. 本来正常步骤是需要将服务提供者的接口打包,然后用pom文件导入,我们这里使用简单的方式,直接将服务的接口拿过来,路径必须保证正确,即和服务提供者相同;

在这里插入图片描述

将provider-service的TicketService复制一份到consumer-service注意要相同目录

启动两个项目的启动类,注意配置文件中的端口号配置成不一样的,然后打开http://localhost:7001登录,服务治理-服务

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

提供者和消费者都有显示,搭建成功,后台一定要挂着zookeeper的服务。

总结

这就是SpingBoot + dubbo + zookeeper实现分布式开发的应用,其实就是一个服务拆分的思想。只是一个小小的实现,个人感觉还是挺容易理解的,主要是搭建zookeeper的环境要注意下细节,还有项目中导包注解不要导错,因为@service有两个选择,一个是spring一个是dubbo的。还有就是正常开发是需要将服务提供者的接口打包,然后用pom文件导入,我们这里使用简单的方式,直接将服务的接口拿过来,路径必须保证正确,即和服务提供者相同,正常开发步骤还没学到,后面持续学习中,有相关案例再分享吧0.0。

到此这篇关于SpingBoot+Dubbo+Zookeeper实现简单分布式开发的应用详解的文章就介绍到这了,更多相关SpingBoot+Dubbo+Zookeeper分布式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Springmvc拦截器执行顺序及各方法作用详解

    Springmvc拦截器执行顺序及各方法作用详解

    这篇文章主要介绍了Springmvc的拦截器执行顺序及各方法作用,下面讲实现其接口的写法,先看一下这个接口的三个方法,需要的朋友可以参考下
    2018-07-07
  • java 获取字节码文件的几种方法总结

    java 获取字节码文件的几种方法总结

    这篇文章主要介绍了java 获取字节码文件的几种方法总结的相关资料,这里总结了三种方法帮助大家实现该功能,需要的朋友可以参考下
    2017-08-08
  • 详解Java爬虫利器Jsoup

    详解Java爬虫利器Jsoup

    Jsoup是一款Java语言开发的HTML解析器,用于解析HTML文档以及对HTML文档进行操作,处理等,本文就将详细给大家介绍一下Java中的爬虫利器Jsoup,感兴趣的同学可以参考一下
    2023-06-06
  • Java 多个异常共享同一个异常处理器的方法

    Java 多个异常共享同一个异常处理器的方法

    这篇文章主要介绍了Java 多个异常共享同一个异常处理器的方法,Java 的异常处理机制,在 Java 7 中有了非常大的改进。其中一个特性就是,支持多个异常共享同一个异常处理器。,需要的朋友可以参考下
    2019-06-06
  • Java进阶之FileUpload完成上传的实例

    Java进阶之FileUpload完成上传的实例

    这篇文章主要介绍了 Java进阶之FileUpload完成上传的实例的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-09-09
  • 基于Spring开发之自定义标签及其解析

    基于Spring开发之自定义标签及其解析

    Spring框架是现在Java最流行的开源框架之一,需要实现一些自定义的标签,主要是方便使用我们框架的人能够快速、简单进行配置,有兴趣的可以了解一下。
    2017-04-04
  • 详解Spring 框架中切入点 pointcut 表达式的常用写法

    详解Spring 框架中切入点 pointcut 表达式的常用写法

    这篇文章主要介绍了详解Spring 框架中切入点 pointcut 表达式的常用写法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • SpringBoot通过ThreadLocal实现登录拦截详解流程

    SpringBoot通过ThreadLocal实现登录拦截详解流程

    这篇文章主要介绍了SpringBoot(HandlerInterceptor)+ThreadLocal实现登录拦截,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • 带你全面认识Java中的异常处理

    带你全面认识Java中的异常处理

    在你所写过的代码中,你已经接触过一些异常了,我们可以通过一些简单的代码让我们理解一些简单的异常,下面这篇文章主要给大家介绍了关于Java中异常处理的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • Java最简单的DES加密算法实现案例

    Java最简单的DES加密算法实现案例

    下面小编就为大家带来一篇Java最简单的DES加密算法实现案例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06

最新评论