springCloud

spring Cloud的核心组件

1. Eureka(注册中心)

当然能做为微服务注册中心的不止eureka,例如还有阿里的nacos等

1.1功能与组成

eureka由两个组件组成,eureka服务器和eureka客户端,eureka服务器用作服务注册服务器;eureka客户端时一个java客户端,用来简化与服务器的交互,作为轮询负载均衡器,并提供服务的故障切换支持。
服务注册与发现

  • eureka Client:负责将这个服务注册到eureka Server中
  • eureka server:注册中心,里面有一个注册表,保存各个服务所在的机器和端口号。

2.Feign

远程调用服务,面向接口
feign是声明式web service客户端,它让微服务之间的调用变得更简单了,类似controller调用service。Sring Cloude集成Ribbon和Eureka,可在使用Feign时提供负载均衡的 http客户端。只需要创建一个接口,然后添加注解即可。

2.1feign能干什么

在feign的实现下,我们只需要创建一个接口并使用注解的方式来配置它(类似于以前的Dao接口上标注mapper,现在是一个微服务接口上面标注一个feign注解即可)

2.2feign原理

feign的一个关键机制就是使用动态代理:

  • 首先,如果你对某个接口定义了@FeignClient注解,Feign就会针对这个接口创建动态代理。
  • 接着你要调用那个接口,本质上就会调用feign创建的动态代理
  • feign动态代理会根据你在接口上的@RequestMapping等注解,来动态构造出,你要请求的服务的地址
  • 最后针对这个地址,发起请求,解析响应

3.Ribbon(负载均衡)

客户端负载均衡工具
例如一个服务部署在多台机器上,此时feign如何确定请求那台服务器呢?

  • ribbon就是专门解决这个问题的,他的作用是负载均衡,会帮助你在每一次请求时选择一台机器,均匀把请求分发到各个机器上。
  • ribbon负载均衡默认使用的最经典Round Robin轮询算法

4.Hystrix(服务熔断)

熔断机制是应对雪崩效应的一种微服务链路保护机制,当链路的某个微服务出错不可用或响应时间过长时,会进行服务降级,进而熔断该节点服务的调用,快速返回错误的相应信息。
当检查到该节点微服务调用响应正常后,恢复调用链路。

5.Zuul(网关)

前端,移动端要调用后端系统,统一从Zuul网关进入,由zuul网关转发请求给对应的服务

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值