Feign

Feign

是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。

在Spring Cloud中,使用Feign非常简单——创建一个接口,并在接口上添加一些注解,代码就完成了。Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。

Spring Cloud对Feign进行了增强,使Feign支持了Spring MVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。

Spring Cloud Feign是基于Netflix feign实现,整合了Spring Cloud Ribbon和Spring Cloud Hystrix,除了提供这两者的强大功能外,还提供了一种声明式的Web服务客户端定义的方式。

Spring Cloud Feign帮助我们定义和实现依赖服务接口的定义。在Spring Cloud feign的实现下,只需要创建一个接口并用注解方式配置它,即可完成服务提供方的接口绑定,简化了在使用Spring Cloud Ribbon时自行封装服务调用客户端的开发量。

1)引入Feign的依赖

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

2)给主函数加注解

@EnableFeignClients
@SpringCloudApplication
public class ConsumerApplication {
   // @Bean
   //  @LoadBalanced //底层用了拦截器,拦截restTemplate 的http请求,使用负载均衡算法处理请求
   //  public RestTemplate restTemplate() {
   //     return new RestTemplate();
   //}

    public static void main(String[] args) {
        SpringApplication.run(ConsumerApplication.class);
    }

3)编写一个接口,利用SpringMVC的方式,告诉Feign请求的方式,参数,返回值,方法名。

@FeignClient("user-service")
public interface UserClient {
    @GetMapping("user/{id}")
    User queryById(@PathVariable("id") Integer id);
}

4)Controller类

  @Autowired
  private UserClient userClient;
  @GetMapping("{id}")
  public User queryById(@PathVariable("id")Integer id){
 //     String url="http://user-service/user/"+id;
 //     String user=restTemplate.getForObject(url,String.class);
      return userClient.queryById(id);

OK!

ⅡFeign中使用熔断

Feign对Hystix支持。

1)开启熔断

feign: #hystrix在feign里默认是关闭的,需要开启feign的熔断
  hystrix:
    enabled: true

2)定义一个类实现client接口

public class UserClientFallback implements UserClient {//熔断接口实现类
    @Override
    public User queryById(Integer id) {
        User user = new User();
        user.setUsername("未知");
        return user;
    }
}


在接口中,指定实现类
@FeignClient(value = "user-service",fallback = UserClientFallback.class)
public interface UserClient {
    @GetMapping("user/{id}")
    User queryById(@PathVariable("id") Integer id);
}

### Feign技术介绍 Feign 以其声明式的使用方式和灵活的扩展能力,成为微服务架构中实现 HTTP 通信的利器。随着微服务架构的不断发展,Feign 在远程调用中的地位将更加重要[^1]。 Feign 的基本原理是通过接口和注解的方式来定义服务之间的调用,它会根据定义的接口和注解生成代理对象,这个代理对象会处理 HTTP 请求的发送和响应的接收。 ### Feign使用指南 #### 基本使用 定义一个 Feign 客户端接口,使用 `@FeignClient` 注解指定服务名。示例代码如下: ```java import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; @FeignClient(name="systemClient") public interface SystemClient { @RequestMapping(path="/llsydn/importExcel", consumes={"multipart/form-data"}, method = RequestMethod.POST) JsonResult importExcel(@RequestPart(name="file") MultipartFile file); } ``` #### 超时时间设置 可以针对指定的 Feign client 进行超时时间设置,不过文档中未详细给出超时设置代码,通常可以在配置文件中设置,示例如下(不同版本可能有差异): ```yaml feign: client: config: systemClient: connectTimeout: 5000 readTimeout: 5000 ``` #### 日志级别设置 基于配置文件修改 Feign 的日志级别可以针对单个服务,示例如下: ```yaml feign: client: config: userservice: # 针对某个微服务的配置,此处是服务名称 loggerLevel: FULL # 日志级别 ``` ### Feign与SSO结合使用 在实际应用中,若要将 Feign 与 SSO 结合使用,通常需要在 Feign 的请求拦截器中添加 SSO 的认证信息。例如,在请求头中添加 SSO 的 token。示例代码如下: ```java import feign.RequestInterceptor; import feign.RequestTemplate; import org.springframework.stereotype.Component; @Component public class SSOFeignInterceptor implements RequestInterceptor { @Override public void apply(RequestTemplate template) { // 从某个地方获取 SSO 的 token,这里只是示例 String ssoToken = getSSOToken(); template.header("Authorization", "Bearer " + ssoToken); } private String getSSOToken() { // 实现获取 SSO token 的逻辑 return "your_sso_token"; } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值