【SpringBoot】最通俗易懂的分布式学习(一)SpringBoot整合dubbo、zookeeper

【SpringBoot】最通俗易懂的分布式学习(一)SpringBoot整合dubbo、zookeeper,第1张

注:本文章基于尚硅谷Springboot高级特性相关视频及资料进行编写,代码简单,较容易理解,若有问题或者源码资料获取可以在评论区留言或者联系作者!


文章目录
  • 导引
  • 一、doker安装Zookeeper
  • 二、SpringBoot、Dubbo、Zookeeper整合
  • 总结:


导引

分布式应用:在分布式系统中,国内常用zookeeper+dubbo的组合,而SpringBoot推荐使用全栈的Spring,SpringBoot+Spring Cloud。

ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,他是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护,域名服务,分布式同步,组服务等等

Dubbo是Alibaba开源的分布式服务框架,即可以作为ZooKeeper的服务框架,最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合。

一、doker安装Zookeeper

(1)linux系统使用doker安装Zookeper镜像:
docker pull registry.docker-cn.com/library/zookeeper

(2)使用docker run --name zk01 -p 2181:2181--restart always -d {zookeeper的镜像id} 命令启动zookeeper

(3)使用doker ps命令查看zookeeper是否正常运行


二、SpringBoot、Dubbo、Zookeeper整合

将服务提供者注册到注册中心(配置提供者)
(1)创建SpringBoot工程,加入Web依赖
(2)创建一个TickService的接口类。并定义一个返回票数的方法;

public interface TickService(){
public String getTicket();
}

(2)编写上面接口的实现方法TicketServiceImpl implements TicketService()

@Compnent
@Service  //注意这里是dubbo的service注解,将此服务发布出去
public class TicketServiceImpl implements TicketService(){
return "《厉害了,我的国》";

(3)再创建一个工程,选择Web模块作为消费者:

(5)创建一个UserService
(6)引入springboot的dubbo依赖,和zookeeper的客户端工具;

 
  
  <dependency>
      <groupId>com.alibabagroupId>
      <artifactId>dubboartifactId>
      <version>2.6.2version>
  dependency>

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

(7)配置application.propertoces中的一些相关属性;

dubbo.application.name=provider-ticket  //当前项目的名字
dubbo.registry.address=zookeeper://{zookeeper服务的地址}:2181
dubbo.scan.base.package=com.atguigu.ticket.service //发布服务的地址

配置服务消费者
(8).在消费者项目中引入和提供者一样的依赖(同上)
(9)配置消费者配置文件:

dubbo.application.name=comsumer-user //当前项目的名字
dubbo.registry.address=zookeeper://{zookeeper服务的地址}:2181

(9)在消费者项目中引入提供者项目的TicketService文件;

(10)在UserServise文件中使用@Reference注解进行TickService方法注入;

@Service
public class UserSevice{
@Reference
TicketService ticketService;

public void hello(){
String ticket =ticketService.getTicket();
system.out.println();
}
}

(11)在测试文件中进行测试

public class ConsumerUserApplicationTests{
@Autowired
UserService userService;

@Test
public void contextLoads(){
userService.hello();
}
}

(12)在提供者运行的情况下,运行消费者测试文件,运行结果如下所示


总结:

这节学习了SpringBoot的分布式架构,了解了分布式架构的一些原理,并了解了SpringBoot如何整合Dubbo和zookeeper,下一节将学习分布式的另一种方式SpringBoot整合Spring Cloud;


如果感觉内容写的还不错的话,一键三连不迷路!!!!
后面将会更新更多学习内容,一起学习吧!!!!!!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/731066.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-27
下一篇 2022-04-27

发表评论

登录后才能评论

评论列表(0条)

保存