SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用


    • Window下安装Zookeeper和Dubbo-admin

    • 1、Apache官网下载Zookeeper

    • 2、GitHub下载Dubbo-admin

    • 3、SpringBoot + Dubbo + Zookeeper

  • 总结


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

Window下安装Zookeeper和Dubbo-admin

1、Apache官网下载Zookeeper

  1. 点击官网地址下载最新版

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

  3. 将conf目录下的zoo_sample.cfg文件,复制一份,重命名为zoo.cfg
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Zookeeper

  4. 在apache-zookeeper-3.6.2-bin目录下新建两个文件夹data和log
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Dubbo_02

  5. 修改zoo.cfg配置文件
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Dubbo_03
    (修改dataDir的路径和增加dataLogDir分别对应刚刚新建的data和log文件夹)

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

  7. 再运行zkCli.cmd
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Dubbo_04
    证明zookeeper搭建成功(详细的安装步骤百度一大堆)

2、GitHub下载Dubbo-admin

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

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

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

mvn clean package -Dmaven.test.skip=true

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

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

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

登录成功后,查看界面
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Zookeeper_05

3、SpringBoot + Dubbo + Zookeeper

框架搭建

  1. 启动zookeeper !

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

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

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

  5. 项目创建完毕;
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_SpingBoot_06

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

<dependency>
<groupId>org.apache.dubbogroupId>
<artifactId>dubbo-spring-boot-starterartifactId>
<version>2.7.3version>
dependency>


<dependency>
<groupId>com.github.sgroschupfgroupId>
<artifactId>zkclientartifactId>
<version>0.1version>
dependency>


<dependency>
<groupId>org.apache.curatorgroupId>
<artifactId>curator-frameworkartifactId>
<version>2.12.0version>
dependency>
<dependency>
<groupId>org.apache.curatorgroupId>
<artifactId>curator-recipesartifactId>
<version>2.12.0version>
dependency>
<dependency>
<groupId>org.apache.zookeepergroupId>
<artifactId>zookeeperartifactId>
<version>3.4.14version>

<exclusions>
<exclusion>
<groupId>org.slf4jgroupId>
<artifactId>slf4j-log4j12artifactId>
exclusion>
exclusions>
dependency>
  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

  • 11

  • 12

  • 13

  • 14

  • 15

  • 16

  • 17

  • 18

  • 19

  • 20

  • 21

  • 22

  • 23

  • 24

  • 25

  • 26

  • 27

  • 28

  • 29

  • 30

  • 31

  • 32

  • 33

  • 34

  • 35

  • 36

  • 37

  1. 在provider-server项目下写一个服务
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_SpingBoot_07

TicketService.java

public interface TicketService {

public String getTicket();
}
  • 1

  • 2

  • 3

  • 4

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 "枫";
}
}
  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

  • 11

  • 12

  • 13

  • 14

  1. 在consumer-server项目下写一个消费者服务
    SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Dubbo_08

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);
}
}
  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

  • 11

  • 12

  • 13

  • 14

  • 15

  • 16

  • 17

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

SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Zookeeper_09
11. 在consumer-service的配置文件中配置dubbo相关属性!
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_SpingBoot_10
12. 本来正常步骤是需要将服务提供者的接口打包,然后用pom文件导入,我们这里使用简单的方式,直接将服务的接口拿过来,路径必须保证正确,即和服务提供者相同;
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_SpingBoot_11
将provider-service的TicketService复制一份到consumer-service注意要相同目录

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

SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Zookeeper_12
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Zookeeper_13
SpingBoot + Dubbo + Zookeeper实现简单分布式开发的应用_Zookeeper_14
提供者和消费者都有显示,搭建成功,后台一定要挂着zookeeper的服务。

总结

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