java B2B2C Springcloud电子商城系统-Feign负载均衡
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服务
- 导入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)
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
java B2B2C Springcloud仿淘宝电子商城系统-声明式调用Feign之请求参数
1、Feign请求参数说明 Feign是Netflix的产品,Spring Cloud Feign是在原生Feign的基础上进行了封装。由于Spring Cloud Feign引入了许多springmvc的注解,方便springmvc的使用者使用,但同时也给使用者带来了很大的混淆,下面我们简单讲解一下springmvc和Spring Cloud Feign的参数绑定机制。 1.1 SpringMVC请求参数绑定机制 我们通过下面的例子进行讲解: @RestController public class demoController{ @RequestMapping("hello") public String hello(String name){ return "hello"+name; } } 虽然接口很简单,但是SpringMVC在解析请求时为做了很多的事情 @RequestMapping指定请求的路径映射,我们GET,POST,DELETE,PUT的请求都可以映射到这里; SpringMVC提供的参数注解包括@RequestParm,@RequestBody,@PathVari...
- 下一篇
利用Serverless架构下函数计算实现网站文件处理的最佳实践
本文介绍如何通过函数计算实现网站文件管理的最佳实践,包括以下几个功能:•特定图片更新后,自动更新这些特定文件之前的压缩包(compress函数)•自动获取压缩包文件的md5值(get-object-md5函数)•图片压缩包形式上传到OSS后,需要自动解压缩(uncompress函数)•自动获取图片文件的meta信息(get-object-meta函数)•自动爬取素材网站的图片(image-clawer函数)•要下载某个目录的文件的时候,给定bucket和目录,自动打包目录并返回压缩包地址供下载(zip-oss函数)•截取网页的图片并自动保存到OSS上(html2png函数)•统一图片分辨率及加水印利用oss的图片处理功能来实现(watermarker函数) 详细操作步骤文档,请到如下链接下载:https://yq.aliyun.co
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS关闭SELinux安全模块
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Mario游戏-低调大师作品
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8编译安装MySQL8.0.19
- MySQL8.0.19开启GTID主从同步CentOS8