目录
本章以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官方文档查看及使用
总结
目录
重点在于SpringCloud的架构及理念上,了解了SpringCloud的架构在由内往外在
慢慢了解其他扩散组件即可