Spring Cloud 学习笔记01----微服务简介

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: Spring Cloud 是一个基于Spring Boot实现的微服务架构开发工具。它为微服务架构中设计的配置管理、服务治理、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等操作提供了简单的开发方式。

简介


Spring Cloud 是一个基于Spring Boot实现的微服务架构开发工具。它为微服务架构中设计的配置管理、服务治理、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分布式会话和集群状态管理等操作提供了简单的开发方式。

Spring Cloud 包括了多个子项目:

Spring Cloud Config:配置管理工具,支持使用Git 存储配置内容,可以使用它实现应用配置的外部化存储,并支持客户端信息刷新。加密/解密配置内容等。

Spring Cloud Netflix: 核心组件,对多个Netflix OSS 开源套件进行整合。

Eureka: 服务治理组件,包括服务注册中心,服务注册与发现机制的实现。

Hystrix: 容错管理组件,实现断路器模式,帮助服务依赖中出现的延迟和为故障提供强大的容错能力。

Ribbon: 客户端负载均衡的服务调用组件。

Feign: 基于Ribbon和Hystrix的声明式服务调用组件。

Zuul: 网关组件,提供智能路由、访问过滤等功能。

Archaius: 外部化配置组件。

Spring Cloud Bus: 事件、消息总线,用于传播集群中的状态变化或事件,已触发后续的处理,比如用来动态刷新配置等。

Spring Cloud Cluster: 针对Zookeeper、Redis、Hazelcatst、Consul的选举算法和通用状态模式的实现。

Spring Cloud Stream: 通过Redis、Rabbit或者Kafka实现的消费微服务,可以通过简单的声明式模型来发送和接收消息。

Spring Cloud ZooKeeper: 基于ZooKeeper的服务发现和配置管理组件。

微服务架构

简单来说,微服务架构就是将应用从存储开始垂直拆分成一系列小的web 服务,这些服务可以独立的编译及部署。服务之间通过各自暴露的Api 接口(诸如 RESTful API)相互通讯。


功能和使用场景

我们把整个系统根据业务拆分成几个子系统

每个子系统可以部署多个应用,多个应用之间使用负载均衡

需要一个服务注册中心,所有的服务都可以在注册中心注册,负载均衡也是通过注册中心注册的服务来使用一定的策略来实现。

所有的客户端都通过同一个网关地址访问后台的服务,通过路由配置,网关来判断 一个URL请求由哪个服务处理。请求转发到服务上的时候也是使用负载均衡。

服务之间有时候也需要相互访问,例如有一个用户模块,其他服务在处理一些业务的时候,要获取用户服务的用户数据。

需要一个断路器,及时处理服务调用的超时和错误,防止由于其中一个服务的问题导致整体系统的瘫痪。

还需要一个监控功能,监控每个服务调用花费的时间等。

设计原则

单一职责原则

服务自治原则

轻量级通信机制

微服务粒度

整体架构图

163ad88cbc718288259320537c80045e_watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTQ1MzQ4MDg=,size_16,color_FFFFFF,t_70.png


架构图说明

Eureka 负责服务的注册与发现,很好地将各服务连接起来。

Hystrix 负责监控服务之间的调用情况,连续失败多次进行熔断保护。

Hystrix dashboard,Turbine负责监控Hystrix的熔断情况并给予图形化的展示

Spring Cloud Config 提供了同一个的配置中心服务

当配置文件发生变化的时候,Spring Cloud Bus通知各服务去获取罪行的配置信息

所有对外的请求和服务,我们都通过Zuul来进行转发,起到API网关的作用。

监控我们使用Sleuth+Zipkin+SpringAdmin将所有的请求数据记录下来,方便我们进行后续分析。

版本说明

由于Spring Cloud 不像Spring 社区其他的一些项目那样相对独立,它是一个拥有诸多子项目的大型综合项目,可以说是对微服务架构解决方法的综合套件组合,其包含的各个子项目也都独立进行着内容的更新与迭代,各自都维护着自己的发布版本号。因此每一个Spring Cloud的版本都会包含多个不同版本的子项目,为了管理每个版本的子项目清单,避免Spring Cloud的版本号与其子项目的版本号相混淆,没有采用版本号的方式,而是通过命名的方式。

当一个版本的Spring Cloud 项目的发布内容积累到一个临界点或者一个严重的bug解决可用后,就会发布一个“service release ” 版本,简称SRX版本。其中X是一个递增的数字,所以Brixton.SR5就是Brixton的第5个 Release版本。

引用

《Spring Cloud微服务实战》

http://blog.didispace.com/spring-cloud-starter-dalston-1/


相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
1天前
|
Java API 数据格式
Spring三兄弟:Spring、Spring Boot、Spring Cloud的100个常用注解大盘点
Spring三兄弟:Spring、Spring Boot、Spring Cloud的100个常用注解大盘点
25 1
|
4天前
|
存储 搜索推荐 Java
微服务SpringCloud ES分布式全文搜索引擎简介 下载安装及简单操作入门
微服务SpringCloud ES分布式全文搜索引擎简介 下载安装及简单操作入门
17 2
|
6天前
|
前端开发 Java 数据库连接
Spring的工作原理(一)简介
Spring的工作原理(一)简介
8 1
|
8天前
|
安全 Java 数据安全/隐私保护
在Spring Cloud中实现单点登录(Single Sign-On, SSO)
在Spring Cloud中实现单点登录(Single Sign-On, SSO)
36 2
|
8天前
|
监控 Java Sentinel
Spring Cloud微服务架构
Spring Cloud微服务架构
27 1
|
16小时前
|
存储 NoSQL Java
Spring Cloud OAuth2 实现用户认证及单点登录(2)
Spring Cloud OAuth2 实现用户认证及单点登录
|
16小时前
|
存储 Java 数据安全/隐私保护
Spring Cloud OAuth2 实现用户认证及单点登录(1)
Spring Cloud OAuth2 实现用户认证及单点登录
|
23小时前
|
消息中间件 Java 应用服务中间件
Spring Cloud学习之-什么是Spring Cloud?
Spring Cloud学习之-什么是Spring Cloud?
|
1天前
|
Java Nacos 微服务
Spring Cloud微服务在Windows本地开发时禁用Nacos注册中心注册
Spring Cloud微服务在Windows本地开发时禁用Nacos注册中心注册
7 0
|
1天前
|
缓存 Java 微服务
Spring Cloud中@RefreshScope实现动态刷新的原理
Spring Cloud中@RefreshScope实现动态刷新的原理
5 0

热门文章

最新文章