1.新建一个项目 hystrix-feign
2.启动eureka和两个feign client
3.pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.star.guo</groupId>
<artifactId>stage2</artifactId>
<version>0.0.1-SNAPSHOT</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<!-- <groupId>com.star.guo</groupId> -->
<artifactId>hystrix-feign</artifactId>
<!-- <version>0.0.1-SNAPSHOT</version> -->
<packaging>jar</packaging>
<name>hystrix-feign</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Greenwich.M3</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
</project>
4.添加注解
@EnableEurekaClient
@EnableDiscoveryClient
@EnableFeignClients
@EnableHystrix
5.添加和修改配置文件
serviceUrl:
defaultZone: http://localhost:8000/eureka/
server:
port: 8006
spring:
application:
name: hystrix-feign
feign:
hystrix:
enabled: true
6.新建一个Service 接口,一个fallback实现类和一个controlller
@FeignClient(value = "EUREKA-CLIENT",fallback=FeignHystrixFallbackImpl.class)
public interface FeignService {
/**
* hello方法
*
* 本例子未使用其他的路径,如果使用的有配置就行如@GetMapping(value = "/hello")
*
* @param user 用户名称
* @return String
*/
@GetMapping
String hello(@RequestParam(value = "user") String user);
}
@Service
public class FeignHystrixFallbackImpl implements FeignService{
@Override
public String hello(String user) {
// TODO Auto-generated method stub
return "user 传入"+user+"时发生了异常 By Feign";
}
}
/**
* 消息Controller,使用feign测试集群效果
*
* @author Star.Guo
*
*/
@RestController
public class MessageController {
@Autowired
FeignService feignService;
/**
* Hello方法
*
* @param user 用户名
* @return String
*/
@GetMapping
public String hello(String user) {
return feignService.hello(user);
}
}
7.启动访问和测试
http://localhost:8006/?user=star
刷新切换正常,停掉一个之后出现下面内容则正常
user 传入star时发生了异常 By Feign