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)

相关推荐
钱多多_qdd16 小时前
springboot注解(五)
java·spring boot·后端
IT_陈寒17 小时前
React 18实战:这5个新特性让我的开发效率提升了40%
前端·人工智能·后端
a努力。17 小时前
京东Java面试被问:双亲委派模型被破坏的场景和原理
java·开发语言·后端·python·面试·linq
不如打代码KK17 小时前
Springboot如何解决跨域问题?
java·spring boot·后端
蓝程序17 小时前
Spring AI学习 程序接入大模型
java·人工智能·spring
加洛斯18 小时前
SpringSecurity入门篇(1)
后端·架构
一 乐18 小时前
餐厅点餐|基于springboot + vue餐厅点餐系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
用户938169125536018 小时前
Head First 单例模式
后端·设计模式
手握风云-18 小时前
JavaEE 进阶第八期:Spring MVC - Web开发的“交通枢纽”(二)
前端·spring·java-ee
半夏知半秋19 小时前
rust学习-循环
开发语言·笔记·后端·学习·rust