分布式应用简单入门及SpringBoot整合Dubbo+Zookeeper

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
简介: 分布式应用简单入门及SpringBoot整合Dubbo+Zookeeper

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


Dubbo官网架构演变示例图:




单一应用架构

当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键。


垂直应用架构

当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。


分布式服务架构

当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务复用及整合的分布式服务框架(RPC)是关键。


流动计算架构

当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调度和治理中心(SOA)是关键。



【1】Zookeeper和Dubbo

① ZooKeeper

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

简单来说,它是服务注册中心。

② Dubbo

Dubbo是Alibaba开源的分布式服务框架,它最大的特点是按照分层的方式来架构,使用这种方式可以使各个层之间解耦合(或者最大限度地松耦合)。从服务模型的角度来看,Dubbo采用的是一种非常简单的模型,要么是提供方提供服务,要么是消费方消费服务,所以基于这一点可以抽象出服务提供方(Provider)和服务消费方(Consumer)两个角色。


示意图如下,Dubbo容器启动时加载和运行服务提供者(Provider),服务提供者会将自己所能够提供的服务注册到Zookeeper–Registry,服务消费者从Registry中订阅(subscribe)服务,册中心会将服务消费者所需要的服务的地址列表返回给服务消费者。如果服务有变更,Registry将会notify消费者。服务消费者会根据拿到的地址列表,调用服务提供者提供的服务。另外,Dubbo还提供了监控机制(Monitor)。



【2】Docker简单安装Zookeeper

下载镜像命令如下:

docker pull  registry.docker-cn.com/library/zookeeper


启动容器:

官网说明示例如下

docker run --name some-zookeeper --restart always -d zookeeper


This image includes EXPOSE 2181 2888 3888 (the zookeeper client port, follower port, election port respectively), so standard container linking will make it automatically available to the linked containers. Since the Zookeeper “fails fast” it’s better to always restart it.

这里只暴露客户端交互端口2181。

docker run --name zk01 -p 2181:2181 --restart always -d a8a59477268d(镜像id)

【3】编写并配置服务提供者和消费者

① 创建空工程

这里用的是idea。

② 在空工程中分别创建两个Module:consumer-user和provider-ticket

一个是服务消费者,一个是服务提供者。其中user调用ticker的方法。

结构示意图如下:



③ 首先将服务提供者注册到注册中心

三个步骤:

  • 引入dubbo和zkclient相关依赖;
  • 配置dubbo的扫描包和注册中心地址;
  • 使用@Service发布服务

引入依赖pom如下:

    <dependency>
      <groupId>com.alibaba.boot</groupId>
      <artifactId>dubbo-spring-boot-starter</artifactId>
      <version>0.1.0</version>
    </dependency>
    <!--引入zookeeper的客户端工具-->
    <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
    <dependency>
      <groupId>com.github.sgroschupf</groupId>
      <artifactId>zkclient</artifactId>
      <version>0.1</version>
    </dependency>

配置文件如下:

dubbo.application.name=provider-ticket
dubbo.registry.address=zookeeper://192.168.2.110:2181
dubbo.scan.base-packages=com.dubbo.provider.service

provider-ticker如下图所示:


注意这里的@Service非Spring注解而是Dubbo的注解!


启动服务提供者,如下所示,表示正常启动:



④ 服务消费者引用服务

三个步骤:

  • 引入dubbo和zkclient相关依赖;
  • 配置dubbo的注册中心地址;
  • 引用服务

引入依赖同③,application.properties配置如下:

dubbo.application.name=consumer-user
dubbo.registry.address=zookeeper://192.168.2.110:2181

接下来在UserService中引用服务提供者提供的服务!

将TickerService拷贝到位于module consumer-user的同路径下,如下所示:


注意,Dubbo是面向接口的,impl包及实现类不需要!



UserService类如下:

package com.dubbo.consumer.service;
import com.alibaba.dubbo.config.annotation.Reference;
import com.dubbo.provider.service.TicketService;
import org.springframework.stereotype.Service;
/**
 * Created by Janus on 2018/7/11.
 */
@Service//这里是Spring的注解
public class UserService {
    // 远程引用,按照全类名从注册中心寻找
    @Reference
    TicketService ticketService;
    public void hello(){
        String ticket = ticketService.getTicket();
        System.out.println("买到票了:"+ticket);
    }
}

测试类如下:

@RunWith(SpringRunner.class)
@SpringBootTest
public class ConsumerApplicationTests {
  @Autowired
  UserService userService;
  @Test
  public void contextLoads() {
    userService.hello();
  }
}


保持服务提供者正常启动状态,然后服务消费者测试结果如下:


即,通过Zookeeper,服务消费者获取了另一个工程-服务提供者提供的服务!

一个工程引用另一个工程的服务,其实就是远程调用–RPC,常见的如WebService。Dubbo就是基于RPC远程调用实现服务之间的通信!!!


但是本篇博文只是简单实践,实际应用中不可能在消费者下面建立服务提供者同级目录并拷贝接口的。通常是将服务接口抽离到公共接口项目中,消费者和服务提供者依赖该接口项目。


相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
3月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
199 1
|
12天前
|
存储 SpringCloudAlibaba Java
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论。
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,创建并配置 Spring Boot 项目,实现后端 API;然后,使用 Ant Design Pro Vue 创建前端项目,配置动态路由和菜单。通过具体案例,展示了如何快速搭建高效、易维护的项目框架。
131 62
|
2月前
|
存储 运维 NoSQL
分布式读写锁的奥义:上古世代 ZooKeeper 的进击
本文作者将介绍女娲对社区 ZooKeeper 在分布式读写锁实践细节上的思考,希望帮助大家理解分布式读写锁背后的原理。
|
1月前
|
缓存 NoSQL Java
Spring Boot中的分布式缓存方案
Spring Boot提供了简便的方式来集成和使用分布式缓存。通过Redis和Memcached等缓存方案,可以显著提升应用的性能和扩展性。合理配置和优化缓存策略,可以有效避免常见的缓存问题,保证系统的稳定性和高效运行。
47 3
|
2月前
|
JSON 安全 算法
Spring Boot 应用如何实现 JWT 认证?
Spring Boot 应用如何实现 JWT 认证?
79 8
|
2月前
|
存储 Java 关系型数据库
在Spring Boot中整合Seata框架实现分布式事务
可以在 Spring Boot 中成功整合 Seata 框架,实现分布式事务的管理和处理。在实际应用中,还需要根据具体的业务需求和技术架构进行进一步的优化和调整。同时,要注意处理各种可能出现的问题,以保障分布式事务的顺利执行。
89 6
|
2月前
|
消息中间件 Java Kafka
Spring Boot 与 Apache Kafka 集成详解:构建高效消息驱动应用
Spring Boot 与 Apache Kafka 集成详解:构建高效消息驱动应用
57 1
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
124 2
|
3月前
|
Dubbo 应用服务中间件 Apache
Dubbo 应用切换 ZooKeeper 注册中心实例,流量无损迁移
如果 Dubbo 应用使用 ZooKeeper 作为注册中心,现在需要切换到新的 ZooKeeper 实例,如何做到流量无损?
39 4