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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章