>>分享孙卫琴的Java技术专稿和著作 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 8525 个阅读者 刷新本主题
 * 贴子主题:  【Spring Cloud Alibaba专题】OpenFeign开启对请求和响应数据的压缩 回复文章 点赞(0)  收藏  
作者:sunweiqin    发表时间:2022-08-25 09:21:03     消息  查看  搜索  好友  邮件  复制  引用

本文参考孙卫琴,杜聚宾所创作的<<Spring Cloud Alibaba微服务开发宝典>>一书,即将出版

默认情况下,OpenFeign没有开启对请求数据和响应数据的压缩。为了提高网络传输的效率,可以开启对传输数据的gzip压缩功能,需要设置OpenFeign的以下属性:

feign.compression.request.enabled:当取值为true,开启对请求数据的压缩功能。默认值为false。
feign.compression.response.enabled:当取值为true,开启对响应数据的压缩功能。默认值为false。
feign.compression.request.mime-types:指定待压缩的请求数据的类型。
feign.compression.request.min-request-size:指定待压缩的请求数据的临界大小。例如,如果取值为2048,就表示当请求数据的大小超过2048字节,就对其压缩;如果低于2048字节,就不会对其压缩。

问题:“开启对请求数据和响应数据的压缩功能,尽管会提高网络传输的效率,但是也会增加CPU的运行负荷。如何在提高网络传输效率和减轻CPU运行负荷之间进行平衡呢?”
答案:“可以把feign.compression.request.min-request-size属性设置大一点,避免对小规模的请求数据压缩,减少压缩次数。这种折中措施即能减轻CPU运行负荷,也能保证网络传输效率。”

为了使得消费者访问提供者微服务时会启用数据压缩功能,在消费者模块的application.yaml文件中需要加入如下配置属性:

feign:
  compression:
    request:
      enabled: true
      mime-types: text/xml,application/xml,application/json
      min-request-size: 2048
    response:
      enabled: true

当消费者访问提供者微服务时,观察运行消费者模块的IDEA控制台,会看到OpenFeign输出以下FULL级别的日志:

[HelloFeignService#sayHello] --->
  GET http://hello-provider-service/user/greet/Tom HTTP/1.1
[HelloFeignService#sayHello] Accept-Encoding: gzip
[HelloFeignService#sayHello] Accept-Encoding: deflate
[HelloFeignService#sayHello] ---> END HTTP (0-byte body)
……

以上位于请求头中的“Accept-Encoding: gzip”的作用是告诉hello-provider-service微服务,返回按照gzip压缩的响应结果。



程序猿的技术大观园:www.javathinker.net
  Java面向对象编程-->Swing组件(上)
  JavaWeb开发-->JSP中使用JavaBean(Ⅱ)
  JSP与Hibernate开发-->持久化层的映射类型
  Java网络编程-->非阻塞通信
  精通Spring-->Vue简介
  Vue3开发-->通过Axios访问服务器
  【Vue.js技术专题】Vue组件的数据监听
  【Vue.js技术专题】CSS中DOM元素的过渡模式
  【Vue.js技术专题】插槽slot的基本用法
  【Spring Cloud Alibaba专题】ShardingSphere核心概念
  【Spring Cloud Alibaba专题】Dubbo框架中提供者回调消费者
  【Java基础编程专题】使用和创建JavaDoc文档
  向小伙伴们推荐我所创作前后端编程书籍的学习顺序
  【Spring专题】服务器端推送
  【Spring专题】通过JPA API实现Repository接口
  【Vue专题】Vue组件的CSS过渡模式
  【持久化专题】用orphanRemoval属性映射父子关系
  【持久化专题】JPA API的基本用法
  【JavaWeb专题】在Servlet中利用Apache开源类库实现文件上传
  【Java基础编程专题】Java集合与数组的互换
  我的计算机书籍创作心得
  更多...
 IPIP: 已设置保密
树形列表:   
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。