SpringCloud2.0 Hystrix Feign 基于Feign实现断路器

原文:http://www.javashuo.com/article/p-dquylkqj-kg.htmlhtml

 

一、启动【服务中心】集群,工程名:springcloud-eureka-server

二、启动【服务提供者】集群,工程名:springcloud-eureka-client

三、启动【服务消费者】,工程名:springcloud-eureka-feign

四、未加入熔断机制,【服务提供者】出现问题,对【服务消费者】的影响

4.一、停掉【服务提供者】集群中的其中一个服务。本例:停掉端口为 52602 这个服务。

4.二、打开浏览器,访问 http://localhost:52620/feignInfo,屡次刷新该地址

 

调用 5260一、52603 服务是正常的,可是调用52602服务的时候,出现了阻塞等待,并最终返回了红框内的错误信息。浏览器

假如这是正式的生产环境,访问量很大的状况下,那么就会有不少请求阻塞。这会形成【服务消费者】服务器内存消耗陡增,致使应用崩溃。若是有其余应用须要【服务消费者】返回资源信息,那么调用【服务消费者】的应用也会出现阻塞。这就致使了连锁反应,也就是所谓的雪崩。服务器

因此,为了不这种悲剧发生。顺应而生的出现了熔断保护机制。即:访问不通时,要及时做出响应,而不是等待至超时。网络

五、修改【服务消费者】,加入熔断机制

5.一、打开工程:springcloud-eureka-feign

5.二、修改工程 pom.xml 文件,追加 Hystrix 依赖,添加以下内容:

1
2
3
4
< dependency >
     < groupId >org.springframework.cloud</ groupId >
     < artifactId >spring-cloud-starter-netflix-hystrix</ artifactId >
</ dependency >

5.三、修改工程启动类,添加注解 @EnableHystrix

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
package com.miniooc.eurekafeign;
 
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.cloud.openfeign.EnableFeignClients;
 
/**
  * EurekaFeignApplication
  * 应用程序启动类,程序入口
  *
  * @author 宋陆
  * @version 1.0.0
  */
@EnableHystrix // Feign默认是开启,这个注解能够不加的
@EnableDiscoveryClient // 启用 Eureka 服务发现
@EnableFeignClients // 启用 Feign
@SpringBootApplication
public class EurekaFeignApplication {
 
     public static void main(String[] args) {
         SpringApplication.run(EurekaFeignApplication. class , args);
     }
 
}

5.四、修改【服务消费者】服务类, EurekaFeignService,追加 fallback 配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
package com.miniooc.eurekafeign.service;
 
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Service;
import org.springframework.web.bind.annotation.RequestMapping;
 
/**
  * EurekaFeignService
  * 服务消费者,调用服务提供者提供的服务,实现业务
  *
  * @author 宋陆
  * @version 1.0.0
  */
@FeignClient (value = "EUREKA-CLIENT" , fallback = EurekaFeignServiceFailure. class ) // 调用的服务的名称
public interface EurekaFeignService {
 
     @RequestMapping (value = "/info" )
     String getInfo();
 
}

5.五、新增【服务消费者】服务调用失败,回调处理类,EurekaFeignServiceFailure

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
package com.miniooc.eurekafeign.service;
 
import org.springframework.stereotype.Service;
 
/**
  * EurekaFeignServiceFailure
  * 服务消费者,调用服务提供者提供的服务失败,回调处理类
  *
  * @author 宋陆
  * @version 1.0.0
  */
@Service
public class EurekaFeignServiceFailure implements EurekaFeignService {
 
     @Override
     public String getInfo() {
         String message = "网络繁忙,请稍后再试-_-。PS:服务消费者本身提供的信息" ;
         return message;
     }
 
}

5.六、修改工程配置文件 application.yml, 开启 hystrix,追加以下配置

1
2
3
feign:
   hystrix:
     enabled: true

六、加入熔断机制后,【服务提供者】出现问题,对【服务消费者】的影响

6.一、重启【服务提供者】集群,重启【服务消费者】

6.二、停掉【服务提供者】集群中的其中一个服务。本例:停掉端口为 52602 这个服务。

6.三、打开浏览器,访问 http://localhost:52620/feignInfo,屡次刷新该地址

 

调用 5260一、52603 服务是正常的,调用52602服务的时候,没有出现阻塞等待,而是返回了【服务消费者】本身提供的返回信息app

【服务消费者】加入熔断机制结束ide

相关文章
相关标签/搜索