SpringCloud入门简介

1. SpringCloud是什么

SpringCloud是微服务治理方案之一;

SpringCloud与SSM框架和SpringBoot没什么关联

SSM:web应用的开发框架,包含视图层(模型model+视图view+控制器controller),业务层,持久层

SpringBoot:简化SSM的配置,同时提供构建项目的脚手架

那么SpringCloud是什么呢?

SpringCloud是一系列微服务治理组件的集合。

通过这些组件可以方便快捷的管理微服务架构的项目,让项目可维护性更好,开发难度更低,性能更好,更好监控

SpringCloud体系的每一个单体项目,实际上还是SpringBoot项目

2. 项目架构发展

2.1 单体应用

所有的功能都在一个项目内,部署在一台服务器上

只要任何一个controller出现问题,整个业务流程就会崩溃

优点:

  1. 易于集中式开发,测试,部署
  2. 不容易出现重复造轮子的问题

缺点:

  1. 代码维护,重构,困难
  2. 性能出现瓶颈之后只能换更好的服务器,系统拓展性差

2.1.1 Servlet(动态web工程)

不使用maven,依赖jar包需要手动下载到WEB-INF下的lib目录下

前端与后端的一个个Servlet的doPost等方法交互,需要手动配置Servlet的路由

SSM/SSH

将servlet换成了controller

2.2 垂直应用(Mavan聚合项目,前后台分离)

水平拆分(根据业务模块拆分)和垂直拆分(普通用户和管理员用户)

2.2.1 水平拆分

存在重复造轮子的问题

但是可以按需分配流量和资源,垂直调用之间互不影响

2.3 分布式系统

抽取基础服务(登录,权限等),服务之间可以互相调用,提高了代码的复用性和开发效率

缺点:

业务耦合度变高,调用关系复杂,难以维护;

搭建集群之后,很难实现负载均衡

2.4 服务治理(SOA架构)

存在一个企业总线(BUS)将服务节点连接起来

BUS的作用:转换,解释消息和路由

BUS类似于一个计算机网络中的交换机,降低了信息转发的复杂程度

SOA主要用于微服务之前

主要的治理组件是ZooKeeper+Dubbo框架+RPC远程调用协议(TCP也能满足通信,但是代价比较高,这里用RMI即可)

缺点:配置复杂,代码复杂度高

DevOps,敏捷开发,ngnix被用于SOA中

2.5 SpringCloud微服务架构

相比于SOA,配置相当简单

将系统的业务功能划分为极小的独立微服务,每个微服务只关注于完成某个小任务。

系统中的单个微服务可以被独立部署和拓展

各个微服务之间高内聚,松耦合

微服务之间采用轻量化的通信机制(显然不是TCP)暴露接口实现通信

优化了SOA的RPC远程调用的繁琐

2.6 服务网格架构

服务网格(Service Mesh)独立于服务之外运行,是服务间通信的基础设施

包括:数据平台DP,管理配置平台CP,熔断器Circuit Breaker,服务中心Service Discovery以及边车Sidecar

所有服务通过Sidecar通信,Sidecar和网络连接共同组成了服务网格(Service Mesh)

相关推荐
养肥胖虎5 小时前
Docker学习笔记:后端、数据库和反向代理怎么一起跑起来
后端·nginx·docker·postgresql·go·部署
晓杰'6 小时前
从0到1实现 Balatro 游戏后端(2):NestJS框架搭建与项目结构设计
后端·websocket·typescript·node.js·游戏开发·项目实战·nestjs
无所事事O_o6 小时前
二次验证码TOTP 使用说明
后端·二次验证码·谷歌验证器
ltl7 小时前
Multi-Head Attention:为什么要分多个头
后端
ltl7 小时前
Scaled Dot-Product:那个根号 d_k 是怎么来的'
后端
tongluowan0078 小时前
Spring MVC 底层工作流程+源码分析
java·spring·mvc
Hexian25808 小时前
SpringAI系列(基础概念&springai系列 API)
spring·ai
折哥的程序人生 · 物流技术专研9 小时前
《Java 100 天进阶之路》第17篇:Java常用包装类与自动装箱拆箱深入
java·开发语言·后端·面试
IT_陈寒10 小时前
为什么Java的Stream并行处理反而变慢了?
前端·人工智能·后端
孙69034210 小时前
swf 图片转 pdf
java·后端