Http客户端--Feign简介

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Http客户端--Feign简介

@[TOC]

1 Feign简介

  • Feign是一个声明式的http客户端,作用就是帮助我们优雅的实现http请求的发送,解决RestTemplate的问题。

    1.1 RestTemplate发送get请求

          RestTemplateBuilder builder = new RestTemplateBuilder();
          RestTemplate restTemplate = builder.build();
          String url = "https://v2.alapi.cn/api/new/wbtop?num=100&token=4DZmP3cZ930V2z7X";
          String forObject = restTemplate.getForObject(url, String.class);
          JSONObject jsonObject = JSONObject.parseObject(forObject);
          Object data = jsonObject.get("data");
          List<WeiBoHotVO> dataJson = JSONObject.parseArray(data.toString(), WeiBoHotVO.class);
    

    1.2 RestTemplate发送post请求

  • 发送参数
          String url = "*****";
          MultiValueMap map = new LinkedMultiValueMap();
          map.add("username", username);
          map.add("password", password);
          ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, map, String.class);
          return responseEntity.getBody();
    
  • 发送json
          String url = "*****";
          Member member = new Member();
          member.setEmail(username);
          member.setPassword(password);
          ResponseEntity<Member> memberResponseEntity = restTemplate.postForEntity(url, member, Member.class);
          return memberResponseEntity.getBody();
    

    1.3 RestTemplate发送通用请求

    String url = "*****";
          HttpHeaders headers = new HttpHeaders();
          headers.setContentType(MediaType.APPLICATION_JSON_UTF8);
          //设置访问参数
          HashMap<String, Object> params = new HashMap<>();
          params.put("username", username);
          //设置访问的Entity
          HttpEntity entity = new HttpEntity<>(params, headers);
          ResponseEntity<String> result;
          try {
         
              //发起一个POST请求
              result = restTemplate.exchange(url, HttpMethod.POST, entity, String.class);
              JSONObject data = JSONObject.parseObject(result.getBody()).getJSONObject("data");
              return data.getString("id");
          } catch (Exception e) {
         
          }
    

    2 Feign客户端的使用

    2.1 引入依赖

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

    2.2 第二步添加注解@EnableFeignClients

    @EnableFeignClients
    public @interface EnableMyFeignClients{
         
    }
    

    2.3 编写Feign客户端

    声明:服务名称、请求方式、请求路径、请求参数、返回值类型
    @FeignClient("userservice")
    public interface UserClient{
         
      @GetMapping("/user/{id}")
      User findById(@PathVariable("id" Long id));
    }
    

    3 Feign的自定义配置

  • 日志级别NONE、BASIC、HEADERS、FULL
  • 方式一:配置文件
    feign:
      client:
          config:
              default: #全局配置可以指定服务名称
                  loggerLevel: BASIC
    
  • 方式二: java代码
  • 自定义日志

    @Component
    public class RemoteUserFallbackFactory implements FallbackFactory<RemoteUserService>
    {
         
      private static final Logger log = LoggerFactory.getLogger(RemoteUserFallbackFactory.class);
    
      @Override
      public RemoteUserService create(Throwable throwable)
      {
         
          log.error("用户服务调用失败:{}", throwable.getMessage());
          return new RemoteUserService()
          {
         
              @Override
              public R<LoginUser> getUserInfo(String username, String source)
              {
         
                  return R.fail("获取用户失败:" + throwable.getMessage());
              }
    
              @Override
              public R<Boolean> registerUserInfo(SysUser sysUser, String source)
              {
         
                  return R.fail("注册用户失败:" + throwable.getMessage());
              }
          };
      }
    }
    
  • 使用自定义日志
    @FeignClient(contextId = "remoteUserService", value = ServiceNameConstants.SYSTEM_SERVICE, fallbackFactory = RemoteUserFallbackFactory.class)
    

    4 Feign的性能优化

    Feign底层的客户端实现:
  • URLConnection:默认实现,不支持连接池
  • Apache HttpClient:支持连接池
  • OKHttp:支持连接池
    性能优化主要包括:
  • 使用连接池代替默认的URLConnection

    # feign 配置
    feign:
    sentinel:
      enabled: true
    okhttp:
      enabled: true
    httpclient:
      enabled: false
    client:
      config:
        default:
          connectTimeout: 10000
          readTimeout: 10000
    compression:
      request:
        enabled: true
      response:
        enabled: true
    
  • 日志级别,最好用basic或none

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
3月前
使用Netty实现文件传输的HTTP服务器和客户端
本文通过详细的代码示例,展示了如何使用Netty框架实现一个文件传输的HTTP服务器和客户端,包括服务端的文件处理和客户端的文件请求与接收。
103 1
使用Netty实现文件传输的HTTP服务器和客户端
|
5月前
|
开发者 Python
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
120 1
|
6月前
|
Go 开发者
golang的http客户端封装
golang的http客户端封装
133 0
|
7月前
|
JSON 数据格式 Python
Python 的 requests 库是一个强大的 HTTP 客户端库,用于发送各种类型的 HTTP 请求
【6月更文挑战第15天】Python的requests库简化了HTTP请求。安装后,使用`requests.get()`发送GET请求,检查`status_code`为200表示成功。类似地,`requests.post()`用于POST请求,需提供JSON数据和`Content-Type`头。
70 6
|
7月前
|
Java
原生Feign使用详解(HTTP客户端)(二)
原生Feign使用详解(HTTP客户端)(二)
139 1
|
7月前
|
Java API Spring
Spring Boot中使用Feign进行HTTP请求
Spring Boot中使用Feign进行HTTP请求
|
7月前
|
数据采集 Java API
Java HTTP客户端工具的演变之路
Java HTTP客户端工具的演变之路
|
7月前
|
JSON API 数据格式
curl 使用:命令行中的 HTTP 客户端
`curl` 是命令行神器,用于与服务器交互,支持HTTP、HTTPS、FTP等协议。本文教你如何用它做POST请求(-d/--data)、GET请求(-G/-d)、JSON请求(-H &#39;Content-Type: application/json&#39;)和文件上传(-F)。学会这些,轻松测试API、自动化任务。现在就动手试试吧!
82 0
|
7月前
|
JSON 前端开发 JavaScript
Axios是一个基于Promise的HTTP客户端
Axios是一个基于Promise的HTTP客户端
50 0
|
存储 Web App开发 监控
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
我们以前使用过的对hbase和hdfs进行健康检查,及剩余hdfs容量告警,简单易用 1.针对hadoop2的脚本: #/bin/bashbin=`dirname $0`bin=`cd $bin;pwd`STATE_OK=...
1065 0