本文介紹了spring cloud-使用Hystrix實現(xiàn)單個方法的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服務(wù) @GetMapping ( "/get/{id}" ) @HystrixCommand (fallbackMethod= "findByIdFallback" ) // 使用HystrixCommand注解,在fallbackMethod屬性中指定fallback的方法 public User findById( @PathVariable Long id) { return client.findById(id); } // 覆寫fallbackMethod中指定的方法,注意,此方法的返回值,參數(shù)必須與原方法一致 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服務(wù)注冊到Eureka Server上的應(yīng)用名稱 spring.application.name=springboot-rest-template-feign-hystrix eureka.instance.prefer-ip-address=true # Eureka Server注冊服務(wù)的地址 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效果,此處將超時時間設(shè)置成1毫秒 |
五、測試
在瀏覽器中輸入:http://localhost:7904/get/2
測試結(jié)果如下:
{"id":9,"username":"chhliu","name":"zhangsan","age":null,"balance":null}
從上面的測試結(jié)果可以看出,由于連接超時,直接進入了fallback方法。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:http://blog.csdn.net/liuchuanhong1/article/details/54917272