{博学谷学习记录} 超强总结,用心分享|狂野架构师-SpringCloud篇章

SpringCloud作为微服务架构体系,提供了服务发现、配置管理等解决方案。Consul作为一个一体化工具,具备服务发现、健康检查等功能。Feign是轻量级的HTTP客户端,而openFeign则增加了对SpringMVC注解的支持,简化了服务调用。文章介绍了SpringCloud的基本概念、Consul的特性和架构,以及Feign和openFeign在业务场景中的应用。
摘要由CSDN通过智能技术生成

目录

1 SpringCloud介绍

1.1 SpringCloud概述:

1.2 SpringCloud架构:

2 SpringCloud相关组件

2.1 Consul 注册中心:

2.2 Consul的 特性:

2.3 Consul的 架构:

2.4 Feign:

2.5 openFeign:

2.6 openFeign业务场景图

总结


本章以springCloud架构及相关组件来进行讲解

1 SpringCloud介绍

1.1 SpringCloud概述:

springCloud是微服务的一种架构体系(理念),在微服务或分布式的架构场景下,需要解决的一系列问题的解决方案。
而一系列的解决方案组成到一起就形成了springCloud全家桶可以理解为SpringCloud是实现微服务架构的有序集合。

1.2 SpringCloud架构:

2 SpringCloud相关组件

2.1 Consul 注册中心:

Consul 是 HashiCorp 公司推出的开源工具,用于实现分布式系统的服务发现与配置。

与其它分布式服务注册与发现的方案相比较,Consul 的方案更“一站式”,内置了服务注册与发现框架、分布式一致性协议实现、健康检查、Key/Value 存储、多数据中心方案,不再需要依赖其它工具(比如 ZooKeeper 等)。

使用起来也较为简单。

Consul 使用 Go 语言编写,因此具有天然可移植性(支持Linux、windows和MacOS X);安装包仅包含一个可执行文件,方便部署,与 Docker 等轻量级容器可无缝配合。

2.2 Consul的 特性:

服务发现,健康检查,Key/Value 存储,多数据中心,社区活跃

2.3 Consul的 架构:

 agent:  

组成 consul 集群的每个成员上都要运行一个 agent,可以通过 consul agent 命令来启动。

agent可以运行在 server 状态或者 client 状态。自然的,运行在 server 状态的节点被称为 server 节点;运行在client 状态的节点被称为 client 节点。

server 节点

负责组成 cluster 的复杂工作(选举server 自行选举一个 leader、状态维护、转发请求到 leader),以及 consul 提供的服务(响应RPC 请求),以及存放和复制数据。考虑到容错和收敛,一般部署 3 ~ 5 个比较合适。

client 节点

负责转发所有的 RPC 到 server 节点。本身无状态,且轻量级,因此,可以部署大量的client 节点。

可以理解为agent是consul服务集群中的线程执行单元,在consul中的功能由agent完成

 

 

   

2.4 Feign:

Feign是Spring Cloud组件中的一个轻量级RESTful的HTTP服务客户端。

Feign内置了Ribbon,用来做客户端负载均衡,去调用服务注册中心的服务。

Feign的使用方式是:使用Feign的注解定义接口,调用这个接口,就可以调用服务注册中心的服务。

Feign支持的注解和用法请参考官方文档:https://github.com/OpenFeign/feign

Feign本身不支持Spring MVC的注解,它有一套自己的注解。

2.5 openFeign:

OpenFeign是Spring Cloud 在Feign的基础上支持了Spring MVC的注解,如@RequesMapping等,是一个轻量级的Http封装工具对象,大大简化了Http请求,使得我们对服务的调用转换成了对本地接口方法的调用。

OpenFeign 的 @FeignClient 可以解析SpringMVC的 @RequestMapping 注解下的接口,并通过动态代理的方式产生实现类,实现类中做负载均衡并调用其他服务。

并且openFeign 集成了Ribbon的负载均衡功能,集成Hystrix的熔断器功能支持请求压缩

大大简化了远程调用的代码,同时功能还增强以更加优雅的方式编写远程调用代码,并简化重复代码

2.6 openFeign业务场景图

 openFeign 具体内置的相关组件大家可参考 openFeign官方文档查看及使用

总结

目录

1 SpringCloud介绍

1.1 SpringCloud概述:

1.2 SpringCloud架构:

2 SpringCloud相关组件

2.1 Consul 注册中心:

2.2 Consul的 特性:

2.3 Consul的 架构:

2.4 Feign:

2.5 openFeign:

2.6 openFeign业务场景图

总结


重点在于SpringCloud的架构及理念上,了解了SpringCloud的架构在由内往外在

慢慢了解其他扩散组件即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值