zoukankan      html  css  js  c++  java
  • Spring Cloud(五)Feign负载均衡

    1 概述

    1.1 介绍

    Feign是一个声明式WebService客户端,使用方法时定义一个接口并在上面添加注解即可。Feign支持可拔插式的编码器和解码器。Spring Cloud对Feign进行了封装,使其支持SpringMVC和HttpMessageConverters。Feign可以与Eureka和Ribbon组合使用以支持负载均衡。

    1.2 由来

    1. 大部分时间我们都能接受ribbon这种直接调用微服务的方式来获取服务:
    private static final String REST_URL_PREFIX = "http://MICROSERVICE-DEPT/";
    
    1. 大家都习惯面向接口编程,比如WebServive,Dao,为了适应广大社区人员提出的面向接口编程原则出现了Feign:
    1. 微服务名字获取调用地址。
    2. 通过接口加注解获取所需服务。

    2 案例

    2.1 新建consumer feign服务

    1. 导入pom.xml
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-feign</artifactId>
        </dependency>
    </dependencies>
    
    1. 编写配置文件。
    server:
      port: 80
    eureka:
      client:
        service-url:
          defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
        register-with-eureka: false    #作为消费者不提供服务,不应该注册自己
    
    1. 创建Feign远程调用接口。
    @FeignClient(name= "spring-cloud-provider")
    public interface HelloRemote {
    
        /**
         * 该抽象方法的注解、访问路径、方法签名要和提供服务的方法完全一致
         * @param name
         * @return
         */
        @RequestMapping(value = "/hello/{name}")
        String hello(@RequestParam(value = "name") String name);
    
    }
    
    1. 编写controller。
    @RestController
    public class ConsumerController {
    
        @Autowired
        HelloRemote HelloRemote;
    	
        @RequestMapping("/hello/{name}")
        public String index(@PathVariable("name") String name) {
            return HelloRemote.hello(name);
        }
    
    }
    
    1. 编写主启动类。
    @SpringBootApplication
    @EnableEurekaClient
    @EnableFeignClients
    public class SpringCloudConsumerFeignApplication80 {
        public static void main(String[] args) {
            SpringApplication.run(SpringCloudConsumerFeignApplication80.class, args);
        }
    }
    
    1. 依次启动uereka、provider、consumer feign服务测试。
      测试结果证明Feign默认使用轮训负载均衡算法
      注意:spring-cloud-starter-feign 里面已经包含了 spring-cloud-starter-ribbon(Feign 中也使用了 Ribbon)
      看源码点这里
    只有把命运掌握在自己手中,从今天起开始努力,即使暂时看不到希望,也要相信自己。因为比你牛几倍的人,依然在努力。
  • 相关阅读:
    【转】C++ 实现线程池
    【转】C++ 实现reactor 模式
    【转】C++ 单例模式
    高并发的内存池——TLS MEMMORY POOL
    爬取某东商品数据
    查看解放号的一些Python岗
    查看前程无忧Python岗及一些可视化
    爬某牙小姐姐视频
    爬取某云音乐热歌榜
    键盘及鼠标记录程序
  • 原文地址:https://www.cnblogs.com/freesky168/p/14358226.html
Copyright © 2011-2022 走看看