首先了解一下什么是Spring Cloud,一般都会有如下解释:
Spring提供了一系列工具,可以帮助开发人员迅速搭建分布式系统中的公共组件(比如:配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁,主节点选举, 分布式session, 集群状态)。协调分布式环境中各个系统,为各类服务提供模板性配置。
Spring Cloud是基于Spring Boot的, 所以最适合用于管理Spring Boot创建的各个微服务应用。Spring Cloud是一系列框架的有序集合。
先来介绍下对于微服务的理解:微服务作为一个业务系统组件可以独立提供离散、自治、可复用的服务。多个服务的组合与编排实现上层业务流程,同时各个服务间隔离(分布式)、自治(分布式依赖整体组合)、其他特性(单一职责,边界,异步通讯,独立部署),形成面向服务架构采用分布式执行的概念。
我们如何发布自己的服务,别人如何调用我们的服务呢?接下来提到的组件即可快速实现服务注册/发现,然后调用。
下面主要介绍下Spring Cloud Netflix几个核心组件:
Eureka:服务治理组件,包含服务注册中心,服务注册与发现机制的实现。功能简化就是服务治理、服务注册/发现。
Hystrix:容错管理,逐渐实现断路模式,帮助服务运行中出现的延迟和为故障提供强大的容错能力。其实是断路器,提供fallback服务进行降级。
Ribbon:客户端负载均衡和服务调用组件。
Feign:基于Ribbon和Hystrix的声明式服务调用组件,使用时不需要显式使用这两个组件。它是一个接出组件可以调用注册在Eureka的服务。
zuul:网关组件,提供智能路由,以及访问过滤功能。
Archaius:外部化配置组件。
这里重点解释一下Feign组件,我们本可以通过RestTemplate调用其它服务的API,为什么要用Feign组件。
Feign是一个声明式的Web Service客户端,它的目的就是让Web Service调用更加简单。Feign提供了HTTP请求的模板,通过 编写简单的接口和插入注解,就可以定义好HTTP请求的参数、格式、地址等信息。
Feign具有如下特性:
1、可插拔的注解支持,包括Feign注解和JAX-RS注解;
2、支持HTTP编码器和解码器;
3、支持Hystrix和它的Fallback;
4、支持Ribbon的负载均衡;
5、支持HTTP请求和响应压缩。
通过使用@FeignClient来映射服务。
大家可以到github下载代码自己运行测试下。
代码地址:https://github.com/witewater/sboot
网上找的几个图,仅供理解:
服务注册/发现


服务容错:

服务依赖


2121

被折叠的 条评论
为什么被折叠?



