SpringCloud之服务消费者(Feign)

一、Feign简介

Feign是一个声明式的伪Http客户端,它使得写Http客户端变得更简单。使用Feign,只需要创建一个接口并注解。它具有可插拔的注解特性,可使用Feign 注解和JAX-RS注解。Feign支持可插拔的编码器和解码器。Feign默认集成了Ribbon,并和Eureka结合,默认实现了负载均衡的效果。

简而言之:

  • Feign 采用的是基于接口的注解

  • Feign 整合了ribbon

    二、准备工作

1.搭建并启动eureka服务

  • 新建springboot项目


  • 名称随意


  • 添加依赖,这里只需eureka server即可

  • 选择项目保存位置,可以按需修改


  • 建好后先在命令行打包检查项目依赖是否有问题



  • 在resource目录下新建配置文件application.yml,内容如下:

    server:
      port: 8761
    spring:
      application:
        name: eureka-server
    
    eureka:
      client:
        registerWithEureka: false
        fetchRegistry: false
        serviceUrl:
          defaultZone: http://127.0.0.1:${server.port}/eureka/
    
  • 在启动类上添加注解@EnableEurekaServer

  • 启动项目,访问 http://127.0.0.1:8761


至此eureka服务搭建完成。

2.创建一个Feign服务

此处取名为feign-load-balance,对应的pom.xml如下:

需要注意的是pom中的Springboot和SpringCloud之间版本对应关系

可以移步至此查看对应版本:https://start.spring.io/actuator/info



    4.0.0
    
        org.springframework.boot
        spring-boot-starter-parent
        1.5.4.RELEASE
         
    
    com.feign.load.balance
    feign-load-balance
    0.0.1-SNAPSHOT
    feign-load-balance
    Demo project for Spring Boot

    
        1.8
        Dalston.SR1
        UTF-8
        UTF-8
    

    
        
            org.springframework.boot
            spring-boot-starter-actuator
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
            org.springframework.cloud
            spring-cloud-starter-eureka
        

        
            org.springframework.cloud
            spring-cloud-starter-feign
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                ${spring-cloud.version}
                pom
                import
            
        
    

    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                ${maven-compiler-plugin.version}
                
                    1.8
                    1.8
                    ${project.build.sourceEncoding}
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    



在配置文件application.yml中指定程序名端口号和eureka注册中心地址

spring:
  application:
    name: feign-load-balance

server:
  port: 9091

eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8761/eureka/

在程序启动类上加上相关注解:


定义一个feign接口,通过@ FeignClient(“服务名”),来指定调用哪个服务。比如在代码中调用了service-hi服务的“/hi”接口,代码如下:

/**
 * @Author YanQiQi
 * @Date 2020-03-10 16:33
 **/
@FeignClient(value = "service-hi")
public interface ScheduleServiceHi {

    /**
     * sayHiFromClientOne
     *
     * @param name name
     * @return String
     */
    @GetMapping(value = "/hi")
    String sayHiFromClientOne(@RequestParam(value = "name") String name);
}

在Web层的controller层,对外暴露一个"/hi"的API接口,通过上面定义的Feign客户端SchedualServiceHi 来消费服务。代码如下:

/**
 * @Author YanQiQi
 * @Date 2020-03-10 16:28
 **/
@RestController
public class HiController {

    @Autowired
    private ScheduleServiceHi scheduleServiceHi;

    @GetMapping("/hi")
    public String sayHello(@RequestParam String name) {
        return scheduleServiceHi.sayHiFromClientOne(name);
    }
}
  • 启动feign-load-balance项目,访问eureka注册中心,可以看到服务注册成功,Feign服务即创建启动完成。


3.创建service-hi(示例服务),使用不同的端口启动,用于测试负载均衡

  • service-hi服务的搭建与上面类似,对应的pom.xml如下:

同样也需要注意Springboot和SpringCloud版本的对应



    4.0.0
    
        org.springframework.boot
        spring-boot-starter-parent
        1.5.4.RELEASE
         
    
    com
    service-hi
    0.0.1-SNAPSHOT
    service-hi
    Demo project for Spring Boot

    
        1.8
        Dalston.SR1
        UTF-8
        UTF-8
    

    
        
            org.springframework.boot
            spring-boot-starter-actuator
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
            org.springframework.cloud
            spring-cloud-starter-eureka
        

        
            org.springframework.cloud
            spring-cloud-starter-feign
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

    
        
            
                org.springframework.cloud
                spring-cloud-dependencies
                ${spring-cloud.version}
                pom
                import
            
        
    

    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                ${maven-compiler-plugin.version}
                
                    1.8
                    1.8
                    ${project.build.sourceEncoding}
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    




  • 在配置文件application.yml中指定程序名端口号和eureka注册中心地址
spring:
  application:
    name: service-hi

server:
  port: 9093
# [9092,9093...]可以多个端口分别启动进行负载均衡
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8761/eureka/
  • 启动类添加相关注解

    @SpringBootApplication
    @EnableEurekaClient
    @EnableFeignClients
    public class ServiceHiApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ServiceHiApplication.class, args);
        }
    
    }
    
  • Controller定义Feign服务要调用的接口,此处为/hi

    /**
     * @Author YanQiQi
     * @Date 2020-03-10 17:14
     **/
    @RestController
    public class HiController {
    
        @Autowired
        private MyConfig myConfig;
    
    
        @GetMapping("/hi")
        public String sayHi(@RequestParam String name) {
            return "hi " + name + "your ip.port is " + myConfig.getPort();
        }
    }
    
  • 分别用90929093端口启动服务

    单个服务多个端口启动时需要在启动时允许并行运行



  • 启动服务后,eureka注册中心如下:


其中service-hi在两个端口启动,Feign服务端调用时会负载均衡到不同的服务上

三、测试结果

多次访问Feign服务端端口可以发现已经实现负载均衡的效果


至此,使用Feign消费服务实现负载均衡完成。

项目源码已经上传至Github

https://github.com/StarryNightBlue/feign-load-balance-demo.git

四、参考资料

https://projects.spring.io/spring-cloud/spring-cloud.html#spring-cloud-feign

https://blog.csdn.net/forezp/article/details/69808079

你可能感兴趣的:(SpringCloud之服务消费者(Feign))