一、在Maven pom.xml文件中添加
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
二、创建一个接口
注意:@FeignClient注解中的cloud-service为Eureka注册的服务名。
原理:在Eureka注册的cloud-service工程中,也有一个controller有相同的findById方法与参数,在此通过Feign接口去跟service-cloud的controller方法匹配
package com.itmuch.cloud;
import org.springframework.cloud.netflix.feign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
@FeignClient(name="cloud-service") // 服务端提供者的name
public interface UserFeignClient {
@GetMapping("/get/{id}")
public User findById(@PathVariable("id") Long id);
}
三、Controller 调用
/**
* #3 第三種 基于 Feign 服务方式来调用
* @param id
* @return
*/
@GetMapping("/feign/{id}")
public User findByIdFeign(@PathVariable Long id) {
return userFeignClient.findById(id);
}
四、主程序
为其添加@EnableFeignClients注解
package com.itmuch.cloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.feign.EnableFeignClients;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class CloudConsumerApplication {
@Bean // 等价于 RestTemplate restTemplate = new RestTemplate();
@LoadBalanced // Ribbon 负载均衡
public RestTemplate restTemplate() {
return new RestTemplate();
}
public static void main(String[] args) {
SpringApplication.run(CloudConsumerApplication.class, args);
}
}