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)

相关推荐
paopaokaka_luck26 分钟前
基于SpringBoot+Vue的电影售票系统(协同过滤算法)
vue.js·spring boot·后端
IT_10246 小时前
Spring Boot项目开发实战销售管理系统——系统设计!
大数据·spring boot·后端
ai小鬼头7 小时前
AIStarter最新版怎么卸载AI项目?一键删除操作指南(附路径设置技巧)
前端·后端·github
Touper.8 小时前
SpringBoot -- 自动配置原理
java·spring boot·后端
一只叫煤球的猫8 小时前
普通程序员,从开发到管理岗,为什么我越升职越痛苦?
前端·后端·全栈
一只鹿鹿鹿8 小时前
信息化项目验收,软件工程评审和检查表单
大数据·人工智能·后端·智慧城市·软件工程
专注VB编程开发20年9 小时前
开机自动后台运行,在Windows服务中托管ASP.NET Core
windows·后端·asp.net
程序员岳焱9 小时前
Java 与 MySQL 性能优化:MySQL全文检索查询优化实践
后端·mysql·性能优化
一只叫煤球的猫9 小时前
手撕@Transactional!别再问事务为什么失效了!Spring-tx源码全面解析!
后端·spring·面试
旷世奇才李先生9 小时前
Ruby 安装使用教程
开发语言·后端·ruby