加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > C语言 > 正文

详解spring cloud使用Hystrix实现单个方法的fallback

发布时间:2020-12-15 01:01:35 所属栏目:C语言 来源:网络整理
导读:本文介绍了spring cloud-使用Hystrix实现单个方法的fallback,分享给大家,具体如下: 一、加入Hystrix依赖 dependency groupIdorg.springframework.cloud/groupId artifactIdspring-cloud-starter-hystrix/artifactId /dependency 二、编写Controller packa

本文介绍了spring cloud-使用Hystrix实现单个方法的fallback,分享给大家,具体如下:

一、加入Hystrix依赖

<dependency> 
      <groupId>org.springframework.cloud</groupId> 
      <artifactId>spring-cloud-starter-hystrix</artifactId> 
    </dependency> 

二、编写Controller

package com.chhliu.springboot.restful.controller;  
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.web.bind.annotation.GetMapping; 
import org.springframework.web.bind.annotation.PathVariable; 
import org.springframework.web.bind.annotation.RestController;  
import com.chhliu.springboot.restful.feignclient.UserFeignClient; 
import com.chhliu.springboot.restful.vo.User; 
import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;  
@RestController 
public class RestTemplateControllerHystrixCommand { 
   
  @Autowired 
  private UserFeignClient client; // 使用Feign来消费Restful服务 
   
  @GetMapping("/get/{id}") 
  @HystrixCommand(fallbackMethod="findByIdFallback")// 使用HystrixCommand注解,在fallbackMethod属性中指定fallback的方法 
  public User findById(@PathVariable Long id) { 
    return client.findById(id); 
  } 
   
    // 覆写fallbackMethod中指定的方法,注意,此方法的返回值,参数必须与原方法一致 
  public User findByIdFallback(Long id){ 
    User u = new User(); 
    u.setName("zhangsan"); 
    u.setUsername("chhliu"); 
    u.setId(9L); 
    return u; 
  } 
} 

三、在启动类中添加Hystrix支持

@EnableCircuitBreaker 

四、添加配置文件

server.port:7904 
# spring boot服务注册到Eureka Server上的应用名称 
spring.application.name=springboot-rest-template-feign-hystrix 
eureka.instance.prefer-ip-address=true 
# Eureka Server注册服务的地址 
eureka.client.service-url.defaultZone=http://chhliu:chhliu123456@localhost:8764/eureka 
springboot-h2.ribbon.NFLoadBalancerRuleClassName=com.netflix.loadbalancer.RetryRule 
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds: 1 #为了测试Hystrix的fallback效果,此处将超时时间设置成1毫秒 

五、测试

在浏览器中输入:http://localhost:7904/get/2

测试结果如下:

{"id":9,"username":"chhliu","name":"zhangsan","age":null,"balance":null} 

从上面的测试结果可以看出,由于连接超时,直接进入了fallback方法。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

您可能感兴趣的文章:

  • 深入解析Spring Cloud内置的Zuul过滤器
  • 深入理解Spring Cloud Zuul过滤器
  • 解决Spring Cloud中Feign/Ribbon第一次请求失败的方法
  • Spring Cloud中关于Feign的常见问题总结
  • JSP spring boot / cloud 使用filter防止XSS
  • spring cloud 之 客户端负载均衡Ribbon深入理解
  • spring cloud 之 Feign 使用HTTP请求远程服务的实现方法
  • 最简单的Spring Cloud教程第一篇:服务的注册与发现(Eureka)
  • spring cloud zuul修改请求url的方法
  • 详解Spring Cloud Zuul中路由配置细节

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读