三、编写服务消费者
1、引入依赖
(1)除了服务提供者的依赖以外,我们再多引入一个依赖,这个依赖实现声明REST调用。我们会在该消费者中声明一个Feign接口,该接口会调用其他服务提供者的内容。在controller中调用该接口。
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
2、启动类上添加@EnableFeignClient注解。
//spring boot 引导类注解 @SpringBootApplication //注册的注解 @EnableDiscoveryClient //调用的注解 @EnableFeignClients
3、在配置文件中添加以下配置,跟服务提供者一致:
#端口号 server.port=9011 #用于指定注册到Eureka Server上的应用名称 spring.application.name=myprovider #设置Eureka Server交互的地址,查询和注册服务都需要依赖这个地址,与注册中心地址一致 eureka.client.service-url.defaultZone=http://localhost:8080/eureka/ #Feign已经为我们集成了Hystrix,经过查证,原来feign集成hystrix需要配置开启 feign.hystrix.enabled=true
4、创建一个Feign接口SchedualServiceHi,并添加@FeignClient注解
(1)注解中的name值是我们调用的其他应用名。该应用名中必须有该类中地址的映射,否则会调用出错。
(2)fallback的值是调用出错时会去调用的方法。
@FeignClient(name= "myprovider",fallback = TestFeignImpl.class) public interface SchedualServiceHi { @RequestMapping("/index") String aa(); @RequestMapping("/bb") public boolean mmm(@RequestParam("name") String name, @RequestParam("pwd") String pwd); }
5、调用出错的类如下,消费者在调用提供者的方法出错时会返回调用这个类对应的方法。
@Component public class TestFeignImpl implements SchedualServiceHi { //降级处理方式 @Override public String aa() { return "provider 容断了"; } @Override public boolean mmm(String name, String pwd) { return false; } }
6、编写该消费者的controller代码,让其调用Feign接口。代码如下:
@RestController public class Testcontroller { @Autowired SchedualServiceHi schedualServiceHi; @RequestMapping("/mindex2") public String mm(){ return schedualServiceHi.aa(); } @RequestMapping("/mindex3") public String mmm(@RequestParam("name") String name, @RequestParam("pwd") String pwd){ if(schedualServiceHi.mmm(name,pwd)){ return "成功"; }else{ return "失败"; } } }
6、启动该项目,访问注册中心,又注册成功了该消费者。
7、分别请求消费者中的映射地址。
(1)地址内如果需要调用Feign接口中的方法,会根据下面指定的服务提供者找到对应的映射地址,返回相应的数据,如果没找到会找下面的fallback,返回错误提示。
@FeignClient(name= "myprovider",fallback = TestFeignImpl.class)
四、总结
1、到此,我们使用几个核心组件,写出了一个简单的Spring Cloud微服务,该服务包括:
(1)注册中心
(2)服务提供者
(3)服务消费者
(4)Feign实现RESTful调用,使得不同服务之间进行通信,共同完成一次客户端的请求。
(5)容错处理类TestFeignImpl