JAVA:Spring Boot 3 实现 Gzip 压缩优化的技术指南

devtools/2024/12/4 16:12:50/

1、简述

随着 Web 应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈。为了减少数据传输量,提高用户体验,我们可以使用 Gzip 压缩 HTTP 响应。本文将介绍如何在 Spring Boot 3 中实现 Gzip 压缩优化。

在这里插入图片描述

2、配置

Spring Boot 3 对 Gzip 压缩提供了开箱即用的支持,我们可以通过简单配置来启用 Gzip 压缩。

2.1 添加依赖

在 Spring Boot 3 项目中,无需额外添加依赖,因为 Gzip 支持是内置的。只需配置即可。

2.2 配置 Gzip 压缩

通过修改 application.yml 或 application.properties 文件,可以轻松启用 Gzip 压缩。

application.yml 配置示例:

server:compression:enabled: truemime-types: text/html, text/xml, text/plain, text/css, text/javascript, application/javascript, application/json, application/xmlmin-response-size: 1024

application.properties 配置示例:

server.compression.enabled=true
server.compression.mime-types=text/html,text/xml,text/plain,text/css,text/javascript,application/javascript,application/json,application/xml
server.compression.min-response-size=1024

配置详解:

  • server.compression.enabled:启用或禁用 Gzip 压缩。设置为 true 以启用压缩。
  • server.compression.mime-types:定义哪些 MIME 类型的响应数据将被压缩。通常我们压缩 HTML、CSS、JavaScript、JSON 等类型的数据。
  • server.compression.min-response-size:设置压缩的最小响应大小(以字节为单位)。如果响应数据小于这个值,将不进行压缩。设置为 1024 表示只有响应大于 1KB 时才会进行压缩。

3、服务端应用

在 Spring Boot 3 中,启用 Gzip 压缩非常简单。以下是如何在后端服务中实现 Gzip 压缩以优化 API 响应数据的示例。假设有一个返回 JSON 数据的 API:

@RestController
public class DataController {@GetMapping("/data")public ResponseEntity<List<String>> getData() {List<String> data = List.of("Item 1", "Item 2", "Item 3", "Item 4", "Item 5");return ResponseEntity.ok(data);}
}

启用 Gzip 压缩后,当数据量较大时,这个 API 响应将被压缩以减少传输的数据量。

你可以使用 curl 来查看后端是否启用了 Gzip 压缩:

curl -H "Accept-Encoding: gzip" -I http://localhost:8080/data

你将会在响应头中看到类似的内容:

Content-Encoding: gzip

这表明 Gzip 压缩已经生效。

4、前端应用

在前端,Gzip 常用于压缩静态资源(如 HTML、CSS、JavaScript 文件),从而减少用户加载页面所需的时间。通常,这些静态资源通过 Web 服务器(如 Nginx 或 Apache)或打包工具(如 Webpack)进行 Gzip 压缩。

4.1 Nginx 配置静态资源的 Gzip 压缩

假设你在前端应用中使用 Nginx 作为静态资源服务器,你可以通过修改 Nginx 配置来启用 Gzip 压缩。Nginx 配置文件 (nginx.conf) 示例:

server {listen 80;server_name example.com;# 启用 gzip 压缩gzip on;gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;gzip_min_length 1024;gzip_comp_level 5;location / {root /var/www/html;try_files $uri $uri/ =404;}
}
  • gzip on:启用 Gzip 压缩。
  • gzip_types:指定要压缩的 MIME 类型(HTML、CSS、JavaScript、JSON 等)。
  • gzip_min_length:仅压缩大于指定长度(1024 字节)的文件。
  • gzip_comp_level:压缩级别(1-9),数字越大压缩越强,但同时 CPU 资源消耗更多。
4.2 使用 Webpack 对前端文件进行 Gzip 压缩

如果你在前端开发中使用 Webpack 构建工具,你可以借助 compression-webpack-plugin 对生成的静态资源进行 Gzip 压缩。

安装插件:

npm install compression-webpack-plugin --save-dev

修改 webpack.config.js:

const CompressionPlugin = require('compression-webpack-plugin');module.exports = {entry: './src/index.js',output: {path: __dirname + '/dist',filename: 'bundle.js'},plugins: [new CompressionPlugin({filename: '[path].gz[query]',algorithm: 'gzip',test: /\.(js|css|html|svg)$/,threshold: 10240,minRatio: 0.8,}),],
};
  • algorithm: ‘gzip’:使用 Gzip 算法。
  • test: /.(js|css|html|svg)$/:指定需要压缩的文件类型。
  • threshold: 10240:仅压缩大小超过 10KB 的文件。
  • minRatio: 0.8:压缩比最小值,只有压缩比小于 0.8 的文件才会被压缩。

运行 Webpack 构建后,静态资源将生成 Gzip 压缩版,服务器可以优先提供这些压缩后的文件给浏览器,减少加载时间。

5、性能提升

使用 Gzip 压缩后,响应数据量可以显著减少,尤其是在数据量较大的情况下,性能提升尤为明显。以下是一些优化结果的示例:

  • 压缩前:原始 JSON 响应大小为 120KB。
  • 压缩后:启用 Gzip 压缩后,响应数据大小减少到 30KB。
    通过减少传输数据的大小,应用的响应速度大幅提升,带宽消耗减少。

注意事项

  • CPU 开销:虽然 Gzip 压缩可以减少传输数据大小,但压缩和解压缩过程会消耗一定的 CPU 资源。如果你的应用对 CPU 敏感,建议合理设置 min-response-size 以避免对小文件进行压缩。
  • 静态资源:对于静态资源(如 CSS 和 JavaScript 文件),如果你使用了 Nginx 或其他代理服务器,建议在代理层进行 Gzip 压缩,而不是在 Spring Boot 中处理。

6、结论

在 Spring Boot 3 中启用 Gzip 压缩是优化应用性能的简单有效方式,尤其适用于需要处理大量静态资源和 API 响应的应用。通过合理的配置,你可以显著减少网络带宽消耗,提升应用的响应速度,从而为用户提供更好的体验。

希望这篇文章能够帮助你在 Spring Boot 3 项目中成功启用 Gzip 压缩,进一步优化你的应用性能。


http://www.ppmy.cn/devtools/139384.html

相关文章

Haproxy高性能负载均衡(天生的负载均衡器)

Haproxy高性能负载均衡(天生的负载均衡器)1.Haproxy相关概念(1)概念HAProxy是可提供高可用性、负载均衡以及基于TCP和HTTP应用的代理HAProxy非常适用于并发大&#xff08;并发达1w以上&#xff09;web站点&#xff0c;这些站点通常又需要会话保持或七层处理可以很简单安全的整合…

Newman+Jenkins实现接口自动化测试(超详细总结)

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、是什么Newman Newman就是纽曼手机这个经典牌子&#xff0c;哈哈&#xff0c;开玩笑啦。。。别当真&#xff0c;简单地说Newman就是命令行版的Postman&…

基于Matlab卡尔曼滤波的GPS/INS集成导航系统研究与实现

随着智能交通和无人驾驶技术的迅猛发展&#xff0c;精确可靠的导航系统已成为提升车辆定位精度与安全性的重要技术。全球定位系统&#xff08;GPS&#xff09;和惯性导航系统&#xff08;INS&#xff09;在导航应用中各具优势&#xff1a;GPS提供全球定位信息&#xff0c;而INS…

【Axure教程】输入框控制多选下拉列表

多选下拉列表是一种常见的用户界面组件&#xff0c;通常用于需要让用户从一组选项中选择多个项的场景。它结合了下拉菜单的简洁性和多选功能的灵活性。 今天我们就来学习&#xff0c;怎么在Axure中制作多选下拉列表&#xff0c;并且通过输入框来动态控制多选列表里的选项。 一…

如何在虚拟机中安装python 和 jupyter,并且启动运行Delta Lake,以及解决一下启动过程中出现的错误(保姆级教程)

文章目录 如何启动Delta Lake环境准备配置环境变量启动Delta Lake 本文演示如何在虚拟机上启动Delta Lake、以及启动期间出现的错误&#xff0c;觉得写的不错的可以三连支持一下哦&#xff01; 如何启动Delta Lake 环境准备 在虚拟机中&#xff1a;安装 Spark 和 jupyterlab…

三维地形图计算软件(四)-用PYQT5+vtk画任意多面体示例

现已完成三维地形图三角网的三维显示和用多线程计算平基土石方功能&#xff0c;正在准备进入将用于计算出的全部三棱柱&#xff08;锥&#xff09;实体也能以三维方式显示出来&#xff0c;并可以选中三维实体和查看他们的属性&#xff0c;现将如何在已知几个点的情况下画出任意…

【再谈设计模式】桥接模式 ~ 抽象与实现的灵活桥梁

一、引言 在软件开发过程中&#xff0c;软件设计中&#xff0c;面对复杂性和变化性时&#xff0c;设计模式提供了一种优雅的解决方案。桥接模式&#xff08;Bridge Pattern&#xff09;是一种结构型设计模式&#xff0c;它通过将抽象与实现分离来实现灵活的扩展。本文将深入探讨…

GitLab使用中遇到的一些问题-记录

错误内容一 Warning: Permanently added gitlab.com (ED25519) to the list of known hosts. gitgitlab.com: Permission denied (publickey). Could not read from remote repository. Please make sure you have the correct access rights and the repository exists. …