前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >springCloud - 第5篇 - 断路器 Hystrix ( Feign 、Ribbon )

springCloud - 第5篇 - 断路器 Hystrix ( Feign 、Ribbon )

作者头像
微风-- 轻许--
发布2019-08-01 15:10:13
2830
发布2019-08-01 15:10:13
举报
文章被收录于专栏:java 微风java 微风

一、为什么要有熔断

在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon和Feign来调用。为了保证其高可用,单个服务通常会集群部署。由于网络原因或者自身的原因,服务并不能保证100%可用,如果单个服务出现问题,调用这个服务就会出现线程阻塞,此时若有大量的请求涌入,Servlet容器的线程资源会被消耗完毕,导致服务瘫痪。服务与服务之间的依赖性,故障会传播,会对整个微服务系统造成灾难性的严重后果,这就是服务故障的 “雪崩” 效应。

为了解决这个问题,业界提出了断路器模型 。 以上出自:https://blog.csdn.net/forezp/article/details/81040990

二、熔断实现

1. 首先 启动 注册中心 eureka 工程、服务生产者 see-param 工程(8803端口)、

服务消费者 feign 工程(8702端口)、服务消费者 ribbon 工程(8701 端口)。

(生产者和消费者这 2 个概念是相对的。在不同的业务场景中,2 者身份可互换。或多服务时,同一服务可兼具 2 个身份。)

分别访问 生产者:

2. feign 中熔断器实现。

配置文件中开启熔断:

代码语言:javascript
复制
# 开启断熔器: ( Feign 自带断路器,但默认为不开启: false)
feign.hystrix.enabled=true

在 SeeParamService 类中 @FeignClient 注解中加上参数 fallback ,并指明熔断方法实现类。

书写 熔断方法实现类:

代码语言:javascript
复制
package com.feign.servicefeign;

import org.springframework.stereotype.Component;

/**
 * @author yujiang
 * @description 迷断回调方法类
 * @date 2019/7/24 9:39
 */

// 注入IOC容器中,把本类交给 spring 管理
@Component
public class SeeParamError implements SeeParamService {

    @Override
    public String seeParam(String param) {
        return " 乖乖加班吧,服务挂了,搬砖,搬砖 ... ";
    }

}

此时, 关闭服务生产者 see-param 工程,并再访问其服务:

至此,feign 熔断生效 。

3. ribbon 中熔断器实现。

ribbon 并不自带迷断功能,故要引入依赖:

代码语言:javascript
复制
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>

工程启动类加注解 @EnableHystrix ,开启熔断。

代码语言:javascript
复制
SeeParamService 类中,在要实现熔断的方法上加注解:@HystrixCommand(fallbackMethod = "熔断实现方法名"),如:
代码语言:javascript
复制
package com.ribbon.serviceribbon;

import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;

/**
 * @author yujiang
 * @description
 * @date 2019/7/22 11:45
 */
@Service
public class SeeParamService {

    @Autowired
    RestTemplate restTemplate;

    /**
     * 注解 @HystrixCommand :
     * 开启熔断器,指定熔断时回调方法为 seeParamError
     *
     * @param param
     * @return
     */
    @HystrixCommand(fallbackMethod = "seeParamError")
    public String seeService(String param) {
        return restTemplate.getForObject("http://see-param/seeParam?param=" + param, String.class);
    }

    /**
     * 熔断 调用此方法
     *
     * @return
     */
    public String seeParamError(String param) {
        return " 哎,别瞅了,别瞅了,服务已经 go die ...";
    }

}

此时, 关闭服务生产者 see-param 工程,并再访问其服务:

至此,ribbon 熔断生效 。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年07月25日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档