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

作者:落叶之枫? 时间:2022-03-02 00:47:40 

开始接触分布式概念,学习之前要准备搭建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

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

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

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

修改zoo.cfg配置文件

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

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

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

再运行zkCli.cmd

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

证明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;

登录成功后,查看界面

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

3、SpringBoot + Dubbo + Zookeeper

框架搭建

  • 启动zookeeper !

  • IDEA创建一个空项目,项目选择最下面那个Empty Project;

  • 创建一个模块,选择Spring Initializr,实现服务提供者:provider-server ,选择web依赖即可

  • 创建一个模块,选择Spring Initializr,实现服务消费者:consumer-service,选择web依赖即可

项目创建完毕;

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

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项目下写一个服务

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

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项目下写一个消费者服务

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

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相关属性!

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

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

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

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

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

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

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

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

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

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

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

来源:https://blog.csdn.net/qq771650656/article/details/113050300

标签:SpringBoot,Dubbo,Zookeeper
0
投稿

猜你喜欢

  • Android实现简单水波纹效果

    2021-11-09 12:40:45
  • Springcloud微服务架构基础知识解析

    2023-01-26 14:37:10
  • Java多线程编程中使用Condition类操作锁的方法详解

    2023-10-19 13:30:55
  • C语言常用占位符的使用小结

    2023-06-10 01:00:04
  • java 文件下载支持中文名称的实例

    2023-03-16 09:02:16
  • Android如何使用圆形揭露动画巧妙地隐藏或显示View详解

    2021-06-21 21:29:51
  • spring中ioc是什么

    2023-07-24 05:38:40
  • C#中Hashtable和Dictionary的区别与用法示例

    2023-10-05 03:22:59
  • springboot乱码问题解决方案

    2022-03-22 21:32:38
  • Android实现GridView中ImageView动态变换的方法

    2022-06-21 06:16:55
  • Java多线程之读写锁分离设计模式

    2021-06-08 07:20:48
  • Android简单创建一个Activity的方法

    2023-01-22 12:39:53
  • 使用springboot整合RateLimiter限流过程

    2022-09-12 21:42:48
  • 浅析java中next与nextLine用法对比

    2022-01-11 01:02:53
  • C#获取每个年,月,周的起始日期和结束日期的方法

    2023-11-11 20:53:45
  • C#中比较常用的DateTime结构的使用方法

    2023-01-06 21:33:11
  • C#中类与接口的区别个人总结

    2023-05-08 17:29:40
  • 使用C#调用百度地图并实现坐标点的设置以及读取示例

    2023-01-06 02:32:57
  • Spring AOP如何整合redis(注解方式)实现缓存统一管理详解

    2023-11-19 06:09:27
  • C#中string.format用法详解

    2023-07-12 21:25:48
  • asp之家 软件编程 m.aspxhome.com