1.ribbon使用hystrix
主類:
@SpringBootApplication
@EnableEurekaClient
//加入支持hystrix註解
@EnableCircuitBreaker
public class SpringCloudMovieApplication {
@Resource
RestTemplateBuilder builder;
@LoadBalanced
@Bean
public RestTemplate restTemplate() {
return builder.build();
}
public static void main(String[] args) {
SpringApplication.run(SpringCloudMovieApplication.class, args);
}
}
MovieController類:
@RestController
public class MovieController {
@Resource
private RestTemplate restTemplate;
@GetMapping("/movie/{id}")
@HystrixCommand(fallbackMethod = "movieFallBack")//加入斷流器hystrix
public User findUserById(@PathVariable long id) {
return this.restTemplate.getForObject("http://spring-cloud-user/user/"+id, User.class);
}
//注意 這裏的返回值與加斷流器的方法的返回值與參數相同
public User movieFallBack(long id) {
User user = new User();
user.setId(id);
return user;
}
當請求失敗這個方法findUserById失敗時,就會直接轉到movieFallBack執行。
2.feign使用hystrix
主類:
@SpringBootApplication
@EnableEurekaClient
//支持聲明式webservice client
@EnableFeignClients
//加入hystrix的依賴
@EnableCircuitBreaker
public class SpringCloudMovieApplication {
public static void main(String[] args) {
SpringApplication.run(SpringCloudMovieApplication.class, args);
}
}
UserService類:
//name屬性表示請求哪個微服務,這裏請求的是用戶微服務,name表示用戶微服務的vip
@FeignClient(name="spring-cloud-user",fallback=UserServiceFallBack.class)
public interface IUserService {
@RequestMapping(value="/user/{id}",method=RequestMethod.GET)//注意,這裏不支持@GetMapping
/**
* @PathVariable("id")不這麼寫,會報如下錯:PathVariable annotation was empty on param 0.
* @param id
* @return
*/
public User findUserById(@PathVariable("id") long id);
}
UserService 熔斷類:
@Component //加入此註解,spring容器實例化
public class UserServiceFallBack implements IUserService{
//feign加入hystrix支持的斷流方法
@Override
public User findUserById(long id) {
User user = new User();
user.setId(id);
return user;
}
}
按道理說這樣配置就算完了,但是,我開始的時候,就是不進熔斷的方法,最後,在eureka server的配置文件中添加:
eureka.client.fetch-registry=true
在feign的配置文件中添加:
feign.hystrix.enabled=true
這樣,feign的熔斷才生效。
至此,簡單的hystrix就介紹完了,歡迎指正。