”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 Spring Boot 和 Spring Cloud 开发微服务

使用 Spring Boot 和 Spring Cloud 开发微服务

发布于2024-11-06
浏览:859

Developing Microservices with Spring Boot and Spring Cloud

微服务架构已成为构建可扩展和模块化系统的流行解决方案。通过微服务,您可以将单一应用程序分解为更小的、独立的和专业的服务,这使得系统的维护和发展变得更加容易。在这篇文章中,我们将探讨如何使用 Spring Boot 和 Spring Cloud 创建健壮且高效的微服务。

微服务简介
微服务背后的主要思想是将应用程序拆分为可以独立开发、部署和扩展的小型服务。每个微服务应该负责特定的功能,并以轻量级的方式与其他服务进行通信,通常使用 REST API 或消息传递。

微服务的一些优点包括:

  • 独立扩展:每个服务都可以单独扩展。
  • 持续部署:您可以更新或修复微服务而不影响其他微服务。
  • 技术灵活性:每个服务可以使用不同的技术和框架来实现。 现在,让我们看看如何使用 Spring Boot 和 Spring Cloud 创建和管理微服务。

现在,让我们看看如何使用Spring BootSpring Cloud创建和管理微服务。

使用 Spring Boot 创建微服务

Spring Boot 专注于最少的配置和快速启动,因此可以轻松构建微服务。让我们首先创建两个微服务:“用户”服务(User-service)和“订单”服务(Order-service)。

  1. 设置 Spring Boot 项目

要设置微服务,您可以使用 Spring Initializr 生成具有所需依赖项的新项目,例如 Spring Web 和 Spring Data JPA。以下是用户服务中 REST 控制器的基本示例:

@RestController
@RequestMapping("/users")
public class UserController {

    @GetMapping("/{id}")
    public ResponseEntity getUserById(@PathVariable Long id) {
        User user = new User(id, "Matheus");
        return ResponseEntity.ok(user);
    }
}

每个微服务可以拥有自己的数据库,保证服务独立、解耦。对于用户服务,我们可以使用 H2 或 PostgreSQL 等配置。

  1. 公开 REST API 每个微服务都通过 REST API 公开其资源,允许其他服务或客户端使用其功能。下面是 Order-service 中使用用户服务 API 的端点示例:
@RestController
@RequestMapping("/orders")
public class OrderController {

    private final RestTemplate restTemplate;

    public OrderController(RestTemplate restTemplate) {
        this.restTemplate = restTemplate;
    }

    @GetMapping("/{id}")
    public ResponseEntity getOrderById(@PathVariable Long id) {
        User user = restTemplate.getForObject("http://user-service/users/"   id, User.class);
        Order order = new Order(id, user, "Order details");
        return ResponseEntity.ok(order);
    }
}

RestTemplate 用于在微服务之间发出 HTTP 请求。

使用 Spring Cloud 管理微服务
虽然 Spring Boot 有助于快速创建微服务,但 Spring Cloud 提供了额外的工具来管理分布式环境中这些服务的通信和弹性。让我们介绍一些基本组件。

  1. 尤里卡发现服务器 微服务的挑战之一是服务发现。 Eureka 是一个发现服务器,允许服务注册自身并发现其他服务,而无需固定 URL。
  • 将 spring-cloud-starter-netflix-eureka-server 依赖添加到 Eureka 服务器。
  • 在User-service和Order-service中配置application.yml文件,注册到Eureka服务器:
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/

现在,服务将自动注册到Eureka,使它们更容易发现彼此。

  1. API 网关与 Spring Cloud Gateway 在微服务架构中,为所有服务提供单一入口点至关重要。 API 网关充当客户端和微服务之间的中介,有效地路由请求。

添加 spring-cloud-starter-gateway 依赖以创建简单网关:

spring:
  cloud:
    gateway:
      routes:
        - id: user-service
          uri: lb://USER-SERVICE
          predicates:
            - Path=/users/**
        - id: order-service
          uri: lb://ORDER-SERVICE
          predicates:
            - Path=/orders/**

这样,任何对 /users/** 的请求都将被路由到用户服务,这同样适用于 /orders/**。

3.** 断路器的弹性 (Hystrix)**

在微服务环境中,失败是不可避免的。 Hystrix 是一个断路器,通过隔离故障来保护服务免受过载。以下是如何将其应用到使用其他服务的方法的示例:

@HystrixCommand(fallbackMethod = "fallbackGetUser")
public User getUser(Long id) {
    return restTemplate.getForObject("http://user-service/users/"   id, User.class);
}

public User fallbackGetUser(Long id) {
    return new User(id, "Default User");
}

如果用户服务失败,将调用fallbackGetUser方法,确保系统保持功能。

Spring Boot 与 Spring Cloud 相结合,为开发可扩展且有弹性的微服务提供了出色的基础设施。借助服务发现、路由和故障管理等功能,您的应用程序将为在分布式动态环境中运行做好充分准备。

无论您是从单体应用程序迁移到微服务还是从头开始,Spring Boot 和 Spring Cloud 都可以加速您的流程并确保坚实的架构。

您喜欢这篇文章吗?如果您有任何问题或建议,请在评论中留下!并且不要忘记与可以从这些技巧中受益的其他开发人员分享。

版本声明 本文转载于:https://dev.to/matheusmartinello/developing-microservices-with-spring-boot-and-spring-cloud-5feh?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 人脸检测失败原因及解决方案:Error -215
    人脸检测失败原因及解决方案:Error -215
    错误处理:解决“ error:((-215)!empty()in Function Multultiscale中的“ openCV 要解决此问题,必须确保提供给HAAR CASCADE XML文件的路径有效。在提供的代码片段中,级联分类器装有硬编码路径,这可能对您的系统不准确。相反,OPENCV提...
    编程 发布于2025-07-03
  • 如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在Java中正确显示“ DD/MM/YYYY HH:MM:SS.SS”格式的当前日期和时间?
    如何在“ dd/mm/yyyy hh:mm:mm:ss.ss”格式“ gormat 解决方案: args)抛出异常{ 日历cal = calendar.getInstance(); SimpleDateFormat SDF =新的SimpleDateFormat(“...
    编程 发布于2025-07-03
  • 如何使用组在MySQL中旋转数据?
    如何使用组在MySQL中旋转数据?
    在关系数据库中使用mySQL组使用mySQL组进行查询结果,在关系数据库中使用MySQL组,转移数据的数据是指重新排列的行和列的重排以增强数据可视化。在这里,我们面对一个共同的挑战:使用组的组将数据从基于行的基于列的转换为基于列。 Let's consider the following ...
    编程 发布于2025-07-03
  • Python中何时用"try"而非"if"检测变量值?
    Python中何时用"try"而非"if"检测变量值?
    使用“ try“ vs.” if”来测试python 在python中的变量值,在某些情况下,您可能需要在处理之前检查变量是否具有值。在使用“如果”或“ try”构建体之间决定。“ if” constructs result = function() 如果结果: 对于结果: ...
    编程 发布于2025-07-03
  • 如何使用Depimal.parse()中的指数表示法中的数字?
    如何使用Depimal.parse()中的指数表示法中的数字?
    在尝试使用Decimal.parse(“ 1.2345e-02”中的指数符号表示法表示的字符串时,您可能会遇到错误。这是因为默认解析方法无法识别指数符号。 成功解析这样的字符串,您需要明确指定它代表浮点数。您可以使用numbersTyles.Float样式进行此操作,如下所示:[&& && && ...
    编程 发布于2025-07-03
  • 如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    如何将多种用户类型(学生,老师和管理员)重定向到Firebase应用中的各自活动?
    Red: How to Redirect Multiple User Types to Respective ActivitiesUnderstanding the ProblemIn a Firebase-based voting app with three distinct user type...
    编程 发布于2025-07-03
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-07-03
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-07-03
  • Java是否允许多种返回类型:仔细研究通用方法?
    Java是否允许多种返回类型:仔细研究通用方法?
    在Java中的多个返回类型:一种误解类型:在Java编程中揭示,在Java编程中,Peculiar方法签名可能会出现,可能会出现,使开发人员陷入困境,使开发人员陷入困境。 getResult(string s); ,其中foo是自定义类。该方法声明似乎拥有两种返回类型:列表和E。但这确实是如此吗...
    编程 发布于2025-07-03
  • 在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    mysql-python安装错误:“ mysql_config找不到”“ 由于缺少MySQL开发库而出现此错误。解决此问题,建议在Ubuntu上使用该分发的存储库。使用以下命令安装Python-MysqldB: sudo apt-get安装python-mysqldb sudo pip in...
    编程 发布于2025-07-03
  • 在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    在Java中使用for-to-loop和迭代器进行收集遍历之间是否存在性能差异?
    For Each Loop vs. Iterator: Efficiency in Collection TraversalIntroductionWhen traversing a collection in Java, the choice arises between using a for-...
    编程 发布于2025-07-03
  • 将图片浮动到底部右侧并环绕文字的技巧
    将图片浮动到底部右侧并环绕文字的技巧
    在Web设计中围绕在Web设计中,有时可以将图像浮动到页面右下角,从而使文本围绕它缠绕。这可以在有效地展示图像的同时创建一个吸引人的视觉效果。 css位置在右下角,使用css float and clear properties: img { 浮点:对; ...
    编程 发布于2025-07-03
  • 如何高效地在一个事务中插入数据到多个MySQL表?
    如何高效地在一个事务中插入数据到多个MySQL表?
    mySQL插入到多个表中,该数据可能会产生意外的结果。虽然似乎有多个查询可以解决问题,但将从用户表的自动信息ID与配置文件表的手动用户ID相关联提出了挑战。使用Transactions和last_insert_id() 插入用户(用户名,密码)值('test','test...
    编程 发布于2025-07-03
  • 如何干净地删除匿名JavaScript事件处理程序?
    如何干净地删除匿名JavaScript事件处理程序?
    删除匿名事件侦听器将匿名事件侦听器添加到元素中会提供灵活性和简单性,但是当要删除它们时,可以构成挑战,而无需替换元素本身就可以替换一个问题。 element? element.addeventlistener(event,function(){/在这里工作/},false); 要解决此问题,请考虑...
    编程 发布于2025-07-03
  • 左连接为何在右表WHERE子句过滤时像内连接?
    左连接为何在右表WHERE子句过滤时像内连接?
    左JOIN CONUNDRUM:WITCHING小时在数据库Wizard的领域中变成内在的加入很有趣,当将c.foobar条件放置在上面的Where子句中时,据说左联接似乎会转换为内部连接。仅当满足A.Foo和C.Foobar标准时,才会返回结果。为什么要变形?关键在于其中的子句。当左联接的右侧值...
    编程 发布于2025-07-03

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3