Idea搭建SpringCloud(四)------利用Feign实现负载均衡

为什么会出现Feign?负载均衡之前不是有Ribbon了吗?

我们之前实现的负载均衡是使用的Ribbon+RestTemplate,在controller中使用RestTemplate根据url去访问服务提供者,而通常我们是在controller中调用我们声明好的service实例去调用我们的逻辑,这样就不符合我们平时面向编程的规范了,所以feign的出现就是解决这个规范问题的。

我们还是基于之前的项目,新建名称为eureka-server-consumer-feign的module,在pom.xml加上feign,ribbon和eureka的依赖

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-feign</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-ribbon</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

新建service包,在里面新建ITestService接口,加上@FeignClient注解。其中name属性为该service是调用哪一组服务提供者的。

@FeignClient(name = "EUREKA-SERVER-PROVIDER")
public interface ITestService {

    @RequestMapping("/provider/test")
    String test();
}

controller中引入ITestService:

@RestController
public class ConsumerController {

    @Autowired
    private ITestService iTestService;

    @RequestMapping("/consumer/test3")
    public String test3(){
        return iTestService.test();
    }

}

启动类,加上@EnableFeignClients注解,@EnableEurekaClient注解,@EnableDiscoveryClient注解:

@SpringBootApplication
@EnableFeignClients
@EnableEurekaClient
@EnableDiscoveryClient
public class EurekaServerConsumerFeignApplication {

    public static void main(String[] args) {
        SpringApplication.run(EurekaServerConsumerFeignApplication.class, args);
    }

}

配置文件application.yml:

server:
  port: 80

eureka:
  client:
    register-with-eureka: false
    service-url:
      defaultZone: http://localhost:7001/eureka/,http://localhost:7002/eureka/,http://localhost:7003/eureka/

启动Eureka集群7001,7002和7003,服务提供者8001,8002和8003,以及我们上面的消费者feign 

结果发现,利用feign也成功实现了负载均衡,其实feign中就是集成了Ribbon的特性。

 

 

 

 

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值