上一章节,讲解了SpringCloud如何经过RestTemplate+Ribbon去负载均衡消费服务,本章主要讲述如何经过Feign去消费服务。html
1、Feign 简介:java
Feign是一个便利的rest框架,在Ribbon的基础上进行了一次改进,采用接口的方式,将须要调用的其余服务的方法定义成抽象方法,不须要本身构建http请求,简化了调用。可是最后的原理仍是经过ribbon在注册服务器中找到服务实例,而后对请求进行分配。web
在工做中,咱们基本上都是使用Feign来进行服务调用,由于Feign使用起来就像是调用自身本地的方法同样,而感受不到是调用远程方法,至关舒服,它主要有3个优势。spring
2、 准备工做:apache
1. 启动eureka-server 工程,eureka注册中心就启动了。编程
2. 启动springcloud-eureka-client工程,springcloud-eureka-client工程的端口为9300。服务器
3. 将springcloud-eureka-client工程的application.properties文件中端口改为9400,而后再启动springcloud-eureka-client。app
经过上面步骤,咱们就启动了端口9300,9400两个同样的springcloud-eureka-client服务模块(为了测试feign的负载均衡能力)。负载均衡
3、新建一个feign服务:框架
1. 新建一个spring-boot工程,取名为springcloud-feign-client,修改pox文件以下:
<parent>标签就是引入咱们第一章节新建的父工程的pom.xml文件,具体可参考:一块儿来学Spring Cloud | 第一章 :如何搭建一个多模块的springcloud项目
<?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.haly</groupId> <artifactId>springcloud</artifactId> <version>0.0.1-SNAPSHOT</version> </parent>
<groupId>com.haly</groupId>
<artifactId>springcloud-feign-client</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springcloud-ribbon-client</name>
<description>新建一个springcloud项目</description>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
2. 修改application.properties文件以下
server.port=9600 spring.application.name=springcloud-feign-client eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
3. 模块启动类须要增长注解@EnableFeignClients,表示开启Feign的功能
package com.haly; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; import org.springframework.cloud.openfeign.EnableFeignClients; @SpringBootApplication @EnableFeignClients @EnableDiscoveryClient public class SpringcloudFeignClientApplication { public static void main(String[] args) { SpringApplication.run(SpringcloudFeignClientApplication.class, args); } }
4. 定义一个feign接口,经过@FeignClient(“服务名”),来指定调用哪一个服务。本章案例中调用了springcloud-eureka-client服务的“/hello”接口
springcloud-eureka-client模块中的hello接口,具体实现能够参考:一块儿来学Spring Cloud | 第二章:服务注册和发现组件 (Eureka)
ps:抽象方法的注解、方法名、参数要和服务提供方保持一致(这里是与springcloud-eureka-client模块中的 /hello方法保持一致)
package com.haly.romote; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; @FeignClient(value = "springcloud-eureka-client") public interface FeignRemoteService { @RequestMapping(value = "/hello",method = RequestMethod.GET) public String hello(@RequestParam(value = "name") String name); }
5. controller层,对外暴露一个"/getHello"的API接口,给页面测试,经过上面定义的Feign客户端FeignRemoteService来消费服务。代码以下:
package com.haly.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import com.haly.romote.FeignRemoteService; @RestController public class FeignController { @Autowired FeignRemoteService feignRemoteService; @GetMapping(value = "/getHello") public String getHello(@RequestParam String name) { return feignRemoteService.hello(name); } }
6. 启动各个服务模块,服务注册结果以下
访问地址 http://localhost:9600/getHello?name=young码农 , 屡次轮流访问页面,出现9300,9400服务接口返回结果,证实feign是整合了负载均衡功能
4、总结:
加上本章节代码后,代码目录结构:
原文出处:https://www.cnblogs.com/haly/p/10857752.html