服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - 详解spring cloud使用Hystrix实现单个方法的fallback

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

2021-03-26 13:39牛奋lch Java教程

本篇文章主要介绍了详解spring cloud-使用Hystrix实现单个方法的fallback,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

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

一、加入Hystrix依赖

?
1
2
3
4
<dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-hystrix</artifactId>
    </dependency>

二、编写Controller

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
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支持

?
1
@EnableCircuitBreaker

四、添加配置文件

?
1
2
3
4
5
6
7
8
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方法。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/liuchuanhong1/article/details/54917272

延伸 · 阅读

精彩推荐