关键词:
1.Feign概述
在上一篇的HelloService这个类中,我们有这样一行代码:
return restTemplate.getForObject("http://hello-service/hello",String.class);
对于代码有一定洁癖的你来说,一定感觉到了,这个url应该是可以被配置的。既然说到配置,那我们首先想到的就是使用java注解的方式。Feign就是这样一个注解框架,它也是netflix为我们提供的,方便我们整合ribbon和hystrix(后面会学习)。
使用Feign,我们能很方便的通过编写接口并插入注解,来定义和代理HTTP请求。Feign主要具备如下特性:
支持Feign注解;
支持Ribbon负载均衡;
支持HTTP编码器和解码器;
提供了熔断器Hystrix;
2.Feign引入
让我们修改ribbon这个项目,使之支持feign。
首先,pom引入,
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<parent>
<artifactId>springcloud.parent</artifactId>
<groupId>com.zuikc</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<packaging>war</packaging>
<name>ribbon</name>
<artifactId>ribbon</artifactId>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Greenwich.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
</dependencies>
</project>
注意pom中的粗体部分。引入Feign依赖,会自动引入Hystrix依赖。
appcation.yml并不需要变动。
修改ServiceRibbonApplication,加入注解@EnableFeignClients,这一步很重要,说明项目对于feign的支持,
package com.zuikc;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
/**
* @ClassName ServiceRibbonApplication
* @Description 我们提供咨询和培训服务,关于本文有任何困惑,请关注并联系“码农星球”
* @Author 码农星球
**/
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class ServiceRibbonApplication
public static void main(String[] args)
SpringApplication.run(ServiceRibbonApplication.class, args);
@Bean
@LoadBalanced
RestTemplate restTemplate()
return new RestTemplate();
4.服务接口
创建一个接口,
package com.zuikc;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
@FeignClient(value = "hello-service")
public interface HelloService
//服务中方法的映射路径
@RequestMapping("/hello")
String hello();
这个接口就比较重要了。
注解@FeignClient说明了,我们需要去eureka服务上去调用“hello-service”这个服务。
注解@RequestMapping指的是我们需要调用的路径。
5.控制器
现在我们还需要最后一步,就是创建一个控制器来接受请求,然后让robbin去分发,
package com.zuikc;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @ClassName ConsumerController
* @Description 我们提供咨询和培训服务,关于本文有任何困惑,请关注并联系“码农星球”
* @Author 码农星球
**/
@RestController
public class HelloController
@Autowired
HelloService helloService;
@RequestMapping("/hello")
public String helloConsumer()
return helloService.hello();
当一切处理完成,让我们启动这个项目,我们仍旧看到ribbon的这个服务,
然后,http://localhost:9291/hello吧,可以看到LB非常的成功。
现在,假设其中一个服务提供者因为某种原因(比如异常、断网)停掉了,看看结果会是怎么样的。为了模拟这个现象,让我们关闭provider2,发现我们无论怎么刷新上面的url,LB永远分配到provider1。这也是分布式系统容错能力更强的一种保证!
感谢关注“码农星球”。本文版权属于“码农星球”。我们提供咨询和培训服务,关于本文有任何困惑,请关注并联系我们。
java微服务之springcloud快速入门day02feign(代码片段)
Java微服务之SpringCloud快速入门day02(二)Feign一、Feign在前面的学习中,我们使用了Ribbon的负载均衡功能,大大简化了远程调用时的代码:StringbaseUrl="http://user-service/user/";Useruser=this.restTemplate.get 查看详情
java微服务之springcloud快速入门day02feign(代码片段)
Java微服务之SpringCloud快速入门day02(二)Feign一、Feign在前面的学习中,我们使用了Ribbon的负载均衡功能,大大简化了远程调用时的代码:StringbaseUrl="http://user-service/user/";Useruser=this.restTemplate.get 查看详情
springcloud项目中通过feign进行内部服务调用发生401407错误无返回信息的问题
问题描述最近在使用SpringCloud改造现有服务的工作中,在内部服务的调用方式上选择了Feign组件,由于服务与服务之间有权限控制,发现通过Feign来进行调用时如果发生了401、407错误时,调用方不能够取回被调用方... 查看详情
springcloud项目中通过feign进行内部服务调用发生401407错误无返回信息的问题(代码片段)
问题描述最近在使用SpringCloud改造现有服务的工作中,在内部服务的调用方式上选择了Feign组件,由于服务与服务之间有权限控制,发现通过Feign来进行调用时如果发生了401、407错误时,调用方不能够取回被调用方... 查看详情
springcloud入门教程:用声明式rest客户端feign调用远端http服务
首先简单解释一下什么是声明式实现?要做一件事,需要知道三个要素,where,what,how。即在哪里(where)用什么办法(how)做什么(what)。什么时候做(when)我们纳入how的范畴。1)编程式实现:每一个要素(where,what,how)都... 查看详情
feign快速入门(代码片段)
...Feign注解和JAX-RS注解,还支持可插拔的编码器与解码器3、SpringCloud增加了对SpringMVC的注解的支持,SpringWeb默认使用了HttpMessageConverters4、SpringCloud集成了Ribbon和Eureka,在使用Feign时提供负载均衡的HTTP客户端二、导入依赖<dependency&g... 查看详情
无废话wcf入门教程一[什么是wcf]
无废话WCF入门教程一[什么是WCF]同学习共进步,微信扫描下面二维码。wcf技术交流,欢迎加群: 群号:274746316一、概述 WindowsCommunicationFoundation(WCF)是由微软发展的一组数据通信的应用程序开发接口,可以翻译为Windows通... 查看详情
springcloud微服务入门
...建配置服务消费者controller新建配置使用Feign负载均衡前言springCloud是一个微服务框架集。eureka来实现zookeeper;Eureka注册中心server新建选择版本:1.5.17clouddicovery---eurekaserver配置启动类#启动类添加注解:@EnableEurekaServ 查看详情
springcloud03ribbon知识点feign知识点利用resttemplate+ribbon调用远程服务提供的资源利用feign调用远程服务提供的资源
1远程服务资源的调用 1.1古老的套路 在微服务出现之前,所有的远程服务资源必须通过RestTemplate或者HttpClient进行;但是这两者仅仅实现了远程服务资源的调用,并未提供负载均衡实现,所以程序员必须自己... 查看详情
springcloud系列之feign-4.feign的动态代理
参考技术ASpring的AOP有两种动态代理方式,其中一种就是前面讲到的Feign采用的方式:JDK动态代理。在Spring中通过JdkDynamicAopProxy实现。它有两个特点实现InvocationHandler接口,接管invoke方法实现自己的业务逻辑,所有调用都会... 查看详情
springcloud之zuul网关入门
SpringCloud实现微服务的架构基本成型: 使用SpringCloudNetflix中的Eureka实现了服务注册中心以及服务注册与发现;而服务间通过Ribbon或Feign实现服务的消费以及均衡负载。 为了使得服务集群更为健壮,使用Hystrix的融断机制来... 查看详情
springcloud学习--feign
...eign注解和JAX-RS注解、Feign还支持可插拔编码器和解码器、SpringCloud增加了对SpringMVC注释的支持,并HttpMessageConverters在SpringWeb中使用了默认使用的相同方式。SpringCloud集成了Ribb 查看详情
springcloud无介绍快使用,ribbon负载均衡工具与openfeign的使用(十五)
参考技术A@TOC从零开始学springcloud微服务项目注意事项:1SpringCloudRibbon是基于NetflixRibbon实现的一套客户端负载均衡的工具2集中式LB3进程内LB4Ribbon本地负载均衡客户端VSNginx服务端负载均衡区别5Ribbon在工作时分成两步6前面几个篇章... 查看详情
08在springcloud中使用feign
SpringCloud对Feign进行了封装,本例将演示如何在SpringCloud中使用Feign。1.准备SpringCloud的测试项目 测试项目主要有三个, a.spring-feign-server:Eureka的服务器项目,端口为8761; b.spring-feign-provider:服务提供者,该项目通过... 查看详情
springcloud-feign
...JAX-RS标准的注解.Feign也支持可拔插式的编码器和解码器.SpringCloud对Feign进行了封装,使其支 查看详情
springcloud之feign客户端
...eign注释和JAX-RS注释。Feign还支持可插拔编码器和解码器。SpringCloud增加了对SpringMVC注释的支持,并使用SpringWeb中默认使用的HttpMessageConverters。SpringCloud集成Ribbon和 查看详情
springcloud-第九篇feign
...么Feign旨在使编写JavaHttp客户端变得更容易。前面在使用SpringCloudRibbon+RestTemplate时,利用RestTemplate对h 查看详情
springcloud---feign服务调用
SpringCloud(5)---Feign服务调用上一篇写了通过Ribbon进行服务调用,这篇其它都一样,唯一不一样的就是通过Feign进行服务调用。注册中心和商品微服务不变,和上篇博客一样,具体参考:SpringCloud(4)---Ribbon服务调用,源码分析这边只... 查看详情