Feign介绍

Feign介绍

以下提到的Fegin指的都是OpenFeign

Feign是一个声明式的http客户端,作用就是帮助我们更快捷,优雅的调用http接口。

1. Feign的使用

  1. 在pom.xml文件中引入feign的依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
  1. 在启动类上添加注解@EnableFeignClients
@EnableDiscoveryClient
@EnableFeignClients
@SpringBootApplication
public class ProductServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(ProductServiceApplication.class, args);
    }
}
  1. 配置Feign接口
@FeignClient(value = "auth-service", path = "/auth")
public interface AuthFeignService {

    @GetMapping(value = "/echo/{string}")
    public String echo(@PathVariable String string);
}
  1. 在controller调用Feign
@RestController
@RequestMapping("/product")
public class ProductController {

    @Autowired
    private AuthFeignService authFeignService;

    @GetMapping(value = "/echo/{string}")
    public String echo(@PathVariable String string){
        String str = authFeignService.echo(string);
        return str;
    }
}

2. Feign底层客户端的实现

  1. URLConnection Feign的默认实现,不支持连接池

  2. Apache HttpClient 支持连接池

  3. OKHttp 支持连接池

3. Feign性能优化

Feign性能主要包括:

  1. 使用带连接池的http请求替代默认的URLConnection
  2. 日志级别,用打印最少的(basic或者none)

3.1 使用连接池替代的URLConnection

  1. pom.xml中引入Apache的HttpClient依赖
<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-httpclient</artifactId>
</dependency>
  1. 配置连接池

在yml文件中添加如下配置:

feign:
  client:
    config:
      default: #这里用default就是全局配置,如果写服务名称,则是针对某个微服务的配置
        loggerLevel: BASIC
  httpclient:
    enabled: true #开启feign对httpClient的支持
    max-connections: 200 #最大的连接数
    max-connections-per-route: 50 #每个路径的最大连接数

3.2 Feign的日志

Feign的日志级别分为四种:

  • NONE:不记录任何日志信息,这是默认值。
  • BASIC:仅记录请求的方法,URL以及响应状态码和执行时间
  • HEADERS:在BASIC的基础上,额外记录了请求和响应的头信息
  • FULL:记录所有请求和响应的明细,包括头信息、请求体、元数据

3.2.1 配置(yml)方式控制日志

  1. 全局配置,针对所有服务
feign:
  client:
    config:
      default: #这里用default就是全局配置,如果写服务名称,则是针对某个微服务的配置
        loggerLevel: BASIC
  1. 针对单个服务
feign:
  client:
    config:
      product-service: #是针对产品微服务的配置
        loggerLevel: BASIC

3.2.2 Java代码方式控制日志

public class DefaultFeignConfiguration  {
    @Bean
    public Logger.Level feignLogLevel(){
        return Logger.Level.BASIC; // 日志级别为BASIC
    }
}
  1. 全局有效:在启动类注解@EnableFeignClients中修改
@EnableFeignClients(defaultConfiguration = FeignClientsConfiguration.class)
  1. 局部有效:修改对应的@FeignClient
@FeignClient(value = "auth-service", path = "/auth", configuration = AuthFeignService.class)

4. 简单SpringCloudAlibaba工程介绍

4.1 结构

在这里插入图片描述

4.2 介绍

  1. springcloud-alibaba上的pom.xml
<?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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.stormkai</groupId>
    <artifactId>springcloud-alibaba</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <modules>
        <module>auth</module>
        <module>product</module>
    </modules>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.12.RELEASE</version>
        <relativePath/>
    </parent>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.2.7.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

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

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
  1. auth的pom.xml文件
<?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/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>springcloud-alibaba</artifactId>
        <groupId>com.stormkai</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>auth</artifactId>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>


    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>

</project>
  1. auth的application.yml
server:
  port: 8721

spring:
  application:
    name: auth-service
  cloud:
    nacos:
      discovery:
        server-addr: 192.168.31.161:8848
management:
  endpoints:
    web:
      exposure:
        include: '*'
  1. auth的启动类AuthServiceApplication
@SpringBootApplication
@EnableDiscoveryClient
public class AuthServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(AuthServiceApplication.class, args);
    }
}
  1. auth的controller类AuthController
@RestController
@RequestMapping("/auth")
public class AuthController {

    @GetMapping(value = "/echo/{string}")
    public String echo(@PathVariable String string) {
        return "Hello Nacos Discovery " + string;
    }

}
  1. product的pom.xml
<?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/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>springcloud-alibaba</artifactId>
        <groupId>com.stormkai</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>product</artifactId>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

        <!--httpClient的依赖-->
        <dependency>
            <groupId>io.github.openfeign</groupId>
            <artifactId>feign-httpclient</artifactId>
        </dependency>
    </dependencies>

</project>
  1. product的application.yml
server:
  port: 8722

spring:
  application:
    name: product-service
  cloud:
    nacos:
      discovery:
        server-addr: 192.168.31.161:8848
management:
  endpoints:
    web:
      exposure:
        include: '*'
feign:
  client:
    config:
      default: #这里用default就是全局配置,如果写服务名称,则是针对某个微服务的配置
        loggerLevel: BASIC
  httpclient:
    enabled: true #开启feign对httpClient的支持
    max-connections: 200 #最大的连接数
    max-connections-per-route: 50 #每个路径的最大连接数

  1. product的启动类ProductServiceApplication
@EnableDiscoveryClient
@EnableFeignClients
@SpringBootApplication
public class ProductServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(ProductServiceApplication.class, args);
    }
}
  1. product的Feign接口的service,AuthFeignService
@FeignClient(value = "auth-service", path = "/auth")
public interface AuthFeignService {

    @GetMapping(value = "/echo/{string}")
    public String echo(@PathVariable String string);
}
  1. product的controller类ProductController
@RestController
@RequestMapping("/product")
public class ProductController {

    @Autowired
    private AuthFeignService authFeignService;

    @GetMapping(value = "/echo/{string}")
    public String echo(@PathVariable String string){
        String str = authFeignService.echo(string);
        return str;
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Feign是一个用于调用远程微服务接口的工具。使用Feign可以方便地进行服务之间的通信。在使用Feign时,我们需要在调用方的启动类上加上Feign客户端的注解,并定义一个代理接口来调用远程服务的接口。通过这个代理接口,我们可以方便地调用远程服务的接口,而无需手动发送HTTP请求,Feign会帮助我们处理这些细节,使得调用更加方便和简洁。 在实际的业务逻辑中,我们可能需要调用多个不同的OpenFeign接口。对于某个服务,我们可能希望设置超时时间。可以通过在Feign的配置文件中配置超时时间来实现。具体的做法是在配置文件中添加以下内容: ``` feign.client.config.default.connectTimeout=5000 feign.client.config.default.readTimeout=5000 ``` 其中,`default`表示默认的超时时间,可以根据需要修改。这样,当调用服务时,Feign会遵循这个超时时间来处理请求。 此外,我们还可以通过使用fallbackFactory来实现容错逻辑。fallbackFactory是一个工厂类,用于生成fallback类的实例。通过配置fallbackFactory属性,可以为每个接口通用的容错逻辑提供支持,避免重复的代码。具体的做法是创建一个实现FallbackFactory接口的工厂类,并在工厂类中实现容错逻辑。然后在调用方的Feign配置中使用该工厂类。当服务出错时,Feign会使用工厂类生成一个fallback对象,并调用对应的降级方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Feign的使用](https://blog.csdn.net/qq_42640067/article/details/112006134)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Feign介绍及使用](https://blog.csdn.net/qq_39749620/article/details/126024319)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值