您现在的位置是:首页 > 文章详情

java B2B2C Springcloud电子商城系统-Feign负载均衡

日期:2019-04-17点击:385

1 概述

1.1 介绍

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

1.2 由来

大部分时间我们都能接受ribbon这种直接调用微服务的方式来获取服务:

private static final String REST_URL_PREFIX = "http://MICROSERVICE-DEPT/";

大家都习惯面向接口编程,比如WebServive,Dao,为了适应广大社区人员提出的面向接口编程原则出现了Feign:

微服务名字获取调用地址。

通过接口加注解获取所需服务。

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>

2.编写配置文件

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 #作为消费者不提供服务,不应该注册自己

3.创建Feign远程调用接口

@FeignClient(name= "spring-cloud-provider") public interface HelloRemote { /** * 该抽象方法的注解、访问路径、方法签名要和提供服务的方法完全一致 * @param name * @return */ @RequestMapping(value = "/hello/{name}") String hello(@RequestParam(value = "name") String name); }

4.编写controller

@RestController public class ConsumerController { @Autowired HelloRemote HelloRemote; @RequestMapping("/hello/{name}") public String index(@PathVariable("name") String name) { return HelloRemote.hello(name); } }

5.编写主启动类

@SpringBootApplication @EnableEurekaClient @EnableFeignClients public class SpringCloudConsumerFeignApplication80 { public static void main(String[] args) { SpringApplication.run(SpringCloudConsumerFeignApplication80.class, args); } }

依次启动uereka、provider、consumer feign服务测试。

测试结果证明Feign默认使用轮训负载均衡算法

注意:spring-cloud-starter-feign 里面已经包含了 spring-cloud-starter-ribbon(Feign 中也使用了 Ribbon)

java B2B2C Springcloud电子商城系统

原文链接:https://yq.aliyun.com/articles/698734
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章