Feign简单案例

Posted shaoxin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Feign简单案例相关的知识,希望对你有一定的参考价值。

Feign是一个声明式的Web Service客户端,它的目的就是让Web Service调用更加简单。Feign提供了HTTP请求的模板,通过编写简单的接口和插入注解,就可以定义好HTTP请求的参数、格式、地址等信息。

Feign = Ribbon(按顺序调用) + RestTemplate

pom.xml添加的配置

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.8</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>$spring-cloud.version</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

application.yml

spring:
  application:
    name: feign
server:
  port: 9093

eureka:
  client:
    service-url:
      defaultZone: http://eureka:[email protected]:8761/eureka,http://eureka:[email protected]:8761/eureka

management:
  endpoint:
    shutdown:
      enabled: true
  endpoints:
     web:
       exposure:
         include:
           - shutdown
           - info
           - health

UserService.java

package com.example.feign.service;

import com.example.feign.entity.User;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;

import java.util.List;

@FeignClient("EUREKA-PROVIDER")
public interface UserService 

    @GetMapping("/getUser")
    public List<User> getUser();

RibbonApplication.java

package com.example.feign;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.openfeign.EnableFeignClients;

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class RibbonApplication 

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

 

以上是关于Feign简单案例的主要内容,如果未能解决你的问题,请参考以下文章

本地调用Feign远程接口

史上最简单的SpringCloud教程 | 第三篇: 服务消费者(Feign)

史上最简单的SpringCloud教程 | 第三篇: 服务消费者(Feign)

SpringCloud + Nacos 简单注册消费例子 | Feign调用

3.spring cloud + zookeeper注册中心 + Feign调用案例

springcloud-feign实现原理,如何实现负载均衡?