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就介绍完了,欢迎指正。