springcloud之hystrix使用

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

你可能感兴趣的:(springcloud)