【Spring】SpringCloud

简介: 【Spring】SpringCloud

一、SpringCloud

Srping Cloud是一系列框架的集合,利用Spring Boot的开发便利性地简化了分布式系统基础设施地开发,

二、微服务介绍

1.系统架构演变

系统架构大体经历了六个过程:单体应用架构->垂直应用架构->分布式架构->SOA架构->微服务架构->Service Mesh(服务网络化)

1.1 单体应用架构

将所有的模块都开发在一个项目下,将一个项目打包成一个war包

优点:

  • 架构图简单易懂
  • 对于一些小型项目来讲,开发维护简单
  • 部署一个单点tomcat上,后期维护方便

缺点:

  • 对大型项目来讲,维护困难
  • 模块之间紧密耦合,单点容错率低
  • 无法针对某一个模块进行水平扩展或优化

1.2 垂直应用架构

优点:

  • 系统之分之后,就可以进行水平扩展和优化
  • 提高了单点容错性

缺点:

  • 系统之间无法相互调用
  • 会有重复代码

1.3 分布式架构

优点:

  • 抽取公共代码为服务层,增强代码复用性

缺点:

  • 调用关系复杂,维护困难

1.4 SOA架构(面向服务的架构)

优点:

  • 使用服务治理中心帮我们维护复杂的调用关系

缺点:

  • 服务有依赖性,可能会因为一个服务的问题导致多个系统不可用(拆分的不够彻底)

1.5 微服务架构(服务的原子化拆分)

微服务架构在某种程度上是面向服务的架构SOA继续发展的下一步,更加强调服务的“彻底拆分”

优点:

  • 服务原子化拆分,独立打包、部署、升级,保证每个微服务清晰的任务划分,利于扩展
  • 微服务之间采用Restful等轻量级http协议相互调用

缺点:

  • 分布式系统开发的技术成本高(容错、分布式事务等)

2.微服务架构介绍

2.1 问题:

  1. 这么多的小服务,我们应该如何管理它们?(服务治理,注册中心(服务注册、发现、剔除))
  2. 这么多的小服务,它们之间应该如何调用?(restful、rpc)
  3. 这么多的小服务,客户端如何来访问它们?(网关)
  4. 这么多的小服务,如果出现了问题,那么作为服务自身来讲,应该如何自处理?(容错)
  5. 这么多的小服务,如何中间哪个环节出了问题,作为程序员来讲,应该如何排查?(链路追踪)

2.2 概念

2.2.1 服务治理

进行服务的自动化管理,核心是服务的自动注册与发现

  • 服务注册:服务实例将自身服务信息注册到注册中心
  • 服务发现:服务实例通过注册中心,获取到注册到其中的服务实例的信息,通过这些信息去请求它们提供的服务
  • 服务剔除:服务注册中心将出问题的服务自动剔除到可用列表之外,使其不会被调用到


相关文章
|
3月前
|
监控 Java API
Spring Boot 3.2 结合 Spring Cloud 微服务架构实操指南 现代分布式应用系统构建实战教程
Spring Boot 3.2 + Spring Cloud 2023.0 微服务架构实践摘要 本文基于Spring Boot 3.2.5和Spring Cloud 2023.0.1最新稳定版本,演示现代微服务架构的构建过程。主要内容包括: 技术栈选择:采用Spring Cloud Netflix Eureka 4.1.0作为服务注册中心,Resilience4j 2.1.0替代Hystrix实现熔断机制,配合OpenFeign和Gateway等组件。 核心实操步骤: 搭建Eureka注册中心服务 构建商品
660 3
|
1月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
8月前
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
9月前
|
前端开发 Java Nacos
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
本文介绍了如何使用Spring Cloud Alibaba 2023.0.0.0技术栈构建微服务网关,以应对微服务架构中流量治理与安全管控的复杂性。通过一个包含鉴权服务、文件服务和主服务的项目,详细讲解了网关的整合与功能开发。首先,通过统一路由配置,将所有请求集中到网关进行管理;其次,实现了限流防刷功能,防止恶意刷接口;最后,添加了登录鉴权机制,确保用户身份验证。整个过程结合Nacos注册中心,确保服务注册与配置管理的高效性。通过这些实践,帮助开发者更好地理解和应用微服务网关。
1680 0
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
|
10月前
|
人工智能 安全 Java
AI 时代:从 Spring Cloud Alibaba 到 Spring AI Alibaba
本次分享由阿里云智能集团云原生微服务技术负责人李艳林主讲,主题为“AI时代:从Spring Cloud Alibaba到Spring AI Alibaba”。内容涵盖应用架构演进、AI agent框架发展趋势及Spring AI Alibaba的重磅发布。分享介绍了AI原生架构与传统架构的融合,强调了API优先、事件驱动和AI运维的重要性。同时,详细解析了Spring AI Alibaba的三层抽象设计,包括模型支持、工作流智能体编排及生产可用性构建能力,确保安全合规、高效部署与可观测性。最后,结合实际案例展示了如何利用私域数据优化AI应用,提升业务价值。
965 4
|
11月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
661 5
|
Java Spring
【Azure Spring Cloud】Spring Cloud Azure 4.0 调用Key Vault遇见认证错误 AADSTS90002: Tenant not found.
【Azure Spring Cloud】Spring Cloud Azure 4.0 调用Key Vault遇见认证错误 AADSTS90002: Tenant not found.
293 1
|
负载均衡 Java API
【Spring Cloud生态】Spring Cloud Gateway基本配置
【Spring Cloud生态】Spring Cloud Gateway基本配置
1108 0
|
Java API 开发工具
Spring Boot与Spring Cloud Config的集成
Spring Boot与Spring Cloud Config的集成