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
在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的服务。
来源:https://blog.csdn.net/qq771650656/article/details/113050300


猜你喜欢
- 光流的概念是由一个叫Gibson的哥们在1950年提出来的。它描述是空间运动物体在观察成像平面上的像素运动的瞬时速度,利用图像序列中像素在时
- 最近在项目中用到了上下滚动展示条目内容,就使用kotlin简单编写实现了一下该功能。使用kotlin实现viewflipper展示textv
- 本文实例讲述了C#敏感词过滤实现方法。分享给大家供大家参考。具体如下:这两天突然想到了敏感词过滤 就结合网上找到的资料自己写了一个,脏字数量
- 本文实例讲述了Android获取SD卡路径及SDCard内存的方法。分享给大家供大家参考。具体分析如下:昨天在研究拍照后突破的存储路径的问题
- //首先导入命名空间 using System.Runtime.InteropServices; /// <summary> /
- C/C++的数据类型:一,整型Turbo C: [signed] int 2Byte//有符号数,-32768~32
- 在实际项目当中,我们经常会涉及到对时间的处理,例如登陆网站,我们会看到网站首页显示XXX,欢迎您!今天是XXXX年。。。。某些网站会记录下用
- 本文介绍了 SpringBoot之Controller的使用,分享给大家,具体如下:1.@Controller:处理http请求 2.@Re
- 本文实例为大家分享了Android自定义轮播图的具体代码,供大家参考,具体内容如下定义Banner主要使用ViewPager实现滑动publ
- CircleImageView实现圆形头像代码分享,供大家参考,具体内容如下一、创建属性文件(attrs.xml)具体操作:1、在项目的va
- 修改Android FloatingActionButton的title的文字颜色及背景颜色实例详解首先看一张图片 我是在一个不错的开源的F
- 前些日子有一个项目需要从word文件中取表格数据并进行处理,网上大部分方案都是基于office的com组件实现,但是这样有一个缺点,如果电脑
- 前言gradle的定义(来自 * )Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化建构工具。它使用一
- 每一个应用程序,其实都会有分享的需求,比如一键分享一篇文章或者一些活动到微博或者微信亦或者是twitter等社交平台,因为人类是社交动物,而
- 一 介绍本节给知识追寻者给大家带来的是springSecurity入门篇,主要是简述下springSecrurity的启动原理和简单的入门搭
- 书上对 i ++ 和 ++ i 的解释如下:int i = 3,a = 0 ;i ++ : 先赋值再运算;例如:a = i ++
- 本文实例为大家分享了Java实现简单的飞机大战游戏,控制主飞机的具体代码,供大家参考,具体内容如下接着上一篇:Java实现简单的飞机大战游戏
- 本文实例讲述了Java基于解释器模式实现定义一种简单的语言功能。分享给大家供大家参考,具体如下:一 模式定 * 释器模式:就是给定一个语言的文
- Android setButtonDrawable()的兼容问题解决办法setButtonDrawable()的兼容问题API1
- 在程序运行中经常需要对数据进行对比显示,其中使用柱状图显示非常直观,可以更显著的比较出数据量的走势。下面介绍在C#中柱状图的制作方法:1、方