如何使用SpringBoot、Dubbo和Zookeeper实现一个简单的分布式应用开发?

2026-04-19 18:092阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1397个文字,预计阅读时间需要6分钟。

如何使用SpringBoot、Dubbo和Zookeeper实现一个简单的分布式应用开发?

开始接触微服务架构概念,学习前需准备搭建Dubbo和Zookeeper环境。Window下安装Zookeeper和Dubbo-admin:

1. 访问Apache官网下载Zookeeper:[Apache Zookeeper](http://www.apache.org/dyn/closer.cgi/zookeeper/)

2.点击官网提供的最新版本下载链接,下载完成后,解压到指定目录,例如`apache-zookeeper-3.7.0-bin.tar.gz`

3.打开`apache-zookeeper-3.7.0-bin.tar.gz`解压后的目录,执行以下命令启动Zookeeper:

bin/zookeeper-server-start.sh config/zookeeper.properties

4.在浏览器中访问`http://localhost:2181`,即可看到Zookeeper的web界面,表示安装成功。

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


如何使用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

执行完毕,我们去访问一下 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> <!-- 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注意要相同目录

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




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

总结

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

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

本文共计1397个文字,预计阅读时间需要6分钟。

如何使用SpringBoot、Dubbo和Zookeeper实现一个简单的分布式应用开发?

开始接触微服务架构概念,学习前需准备搭建Dubbo和Zookeeper环境。Window下安装Zookeeper和Dubbo-admin:

1. 访问Apache官网下载Zookeeper:[Apache Zookeeper](http://www.apache.org/dyn/closer.cgi/zookeeper/)

2.点击官网提供的最新版本下载链接,下载完成后,解压到指定目录,例如`apache-zookeeper-3.7.0-bin.tar.gz`

3.打开`apache-zookeeper-3.7.0-bin.tar.gz`解压后的目录,执行以下命令启动Zookeeper:

bin/zookeeper-server-start.sh config/zookeeper.properties

4.在浏览器中访问`http://localhost:2181`,即可看到Zookeeper的web界面,表示安装成功。

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


如何使用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

执行完毕,我们去访问一下 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> <!-- 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注意要相同目录

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




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

总结

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

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