夏虾er 2023-07-16 10:12 采纳率: 62.5%
浏览 14
已结题

实际开发springcloud微服务的哪些组件是必须,哪些组件是可以根据项目需求不引入的呢

如题,实际开发springcloud微服务的哪些组件是必须,哪些组件是可以根据项目需求不引入的呢。
注册中心肯定的,不用说,网关个人感觉也是必须的,其他的服务熔断,负载均衡,openfeign,配置中心,分布式事务seata。
这些组件,有哪些是可以看需求引入的呢,求详细解答下。

  • 写回答

3条回答 默认 最新

  • 玥轩_521 2023-07-16 10:36
    关注

    在Spring Cloud微服务开发中,以下组件是基本必需的:

    1. 服务注册与发现(Eureka):这是微服务架构中的核心部分,用于管理和发现服务。

    2. 服务网关(Zuul / Spring Cloud Gateway):为微服务应用提供了一种简单有效的前端API接口。

    3. 负载均衡(Ribbon):在调用其他服务时,可以实现客户端的负载均衡。

    4. 声明式REST客户端(Feign):简化了HTTP请求处理,使得写HTTP客户端变得更简单。

    以下组件是可选的,可以根据项目需求选择是否引入:

    1. 断路器(Hystrix):当某个服务出现问题时,可以使用Hystrix来进行熔断和降级,防止系统雪崩。如果你的系统对高可用性要求不高,或者你有其他方式处理这个问题,那么就不需要引入。

    2. 配置中心(Spring Cloud Config):在微服务架构中有一个常见的问题就是如何管理各个分布式组件的配置。Config提供了一个解决方案。如果你的项目并不需要统一管理配置或者已经有其他解决方案,那么就不需要引入。

    3. 分布式事务(Seata):如果你的业务逻辑需要保证ACID事务特性跨多个微服务,那么就需要Seata。但如果你可以通过其他方式来保证数据一致性如最终一致性等,则无需引入Seata。

    4. 链路追踪(Sleuth/Zipkin): 如果你需要对请求进行全链路追踪以便于定位问题和优化性能, 则可以考虑引入。如果你没有这样的需求或者已经有其他工具进行链

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 7月24日
  • 已采纳回答 7月16日
  • 创建了问题 7月16日

悬赏问题

  • ¥15 对回溯算法进行剪枝操作
  • ¥15 安全模式下,用户没有C盘所有权限
  • ¥15 grbl怎么清除一条命令?
  • ¥60 用继电器控制道闸开闸
  • ¥15 grbl移动过程中,发送“!"停止,进入Hold状态,怎么解除?
  • ¥15 wpf中自己实现sorting,每一次都是升序排列
  • ¥15 odoo17中,产品分包路线如何设置?可从销售订单中直接触发采购订单及相关单据
  • ¥15 请教下win10wx和麒麟wx无法互通俩者数据并不兼吗,如何解决?(标签-linux)
  • ¥15 永劫无间游戏如何实现微加速 或者说游戏优化(玩家)
  • ¥15 手机ios升级依赖后app闪退