springcloud无废话入门03:feign声明式服务调用

luminji luminji     2022-12-03     391

关键词:

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并不需要变动。

[email protected]

        修改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服务调用,源码分析这边只... 查看详情