Spring Cloud 入门理解教程

首先了解一下什么是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

 网上找的几个图,仅供理解:

服务注册/发现

 

服务容错:

服务依赖

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值