Netflix:Feign
图
Feign是声明式的web service客户端,它让微服务之间的调用变得更简单了,类似controller调用service,Spring Cloud集成了Ribbon和Eureka,可在使用Feign时提供负载均衡的http客户端

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);
    }
}