Feign
功能与Ribbon一样,也是负载均衡工具,该方式是面向接口编程方式,与Ribbon的区别就是使用方式不同,同时Feign集成了Ribbon,也就是除了使用方式不一样,底层也是Ribbon
Hystrix
在复杂的分布式体系中,服务之间的依赖关系比较多,并形成链路,如果其中某个出现问题,就会导致雪崩效应
服务熔断
添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
<version>1.4.7.RELEASE</version>
</dependency>
编写配置
@RestController
public class Hello {
@RequestMapping("/hello")
// 方法调用失败,设置回调方法
@HystrixCommand(fallbackMethod = "hystrix_hello")
public User hello() {
User user = new User();
user.setName("张三");
System.out.println("访问了提供者8001");
return user;
}
// 备用方法
public User hystrix_hello() {
return new User();
}
}
开启使用
@SpringBootApplication
@EnableEurekaClient
// 开启熔断机制
@EnableCircuitBreaker
public class Pro_8001 {
public static void main(String[] args) {
SpringApplication.run(Pro_8001.class, args);
}
}