当前位置:首页 > 科技  > 软件

Nginx如何开启GZIP文件压缩,你学会了吗?

来源: 责编: 时间:2023-11-30 09:28:11 314观看
导读简介GZip 是一种改进web应用程序性能的技术,文件压缩后再传输可以减少传输数据,提升传输速度。在Nginx服务器上开启Gzip压缩可以有效减少网络传输流量,提升网站的访问速度和性能。可以作用于任何字节流的通用压缩程序。

简介

GZip 是一种改进web应用程序性能的技术,文件压缩后再传输可以减少传输数据,提升传输速度。在Nginx服务器上开启Gzip压缩可以有效减少网络传输流量,提升网站的访问速度和性能。k3N28资讯网——每日最新资讯28at.com

可以作用于任何字节流的通用压缩程序。它会在后台记忆一些之前看到的内容,并尝试以高效方式查找并替换重复的数据片段,从而达到较好的压效果。但使用 gzip 压缩的最大错误之一就是用 gzip 压缩页面中的每个资源文件。k3N28资讯网——每日最新资讯28at.com

支持资源类型

实际上,GZip 主要用于对文本类型的资源进行压缩,例如常用见的文本资源:k3N28资讯网——每日最新资讯28at.com

  • HTML 文件:text/HTML(默认压缩)、application/xhtml+xml
  • CSS 文件:text/css
  • JS 文件:application/x-javascript、application/javascript、text/javascript
  • JSON文件:application/json、application/geo+json、application/ld+json application/manifest+json、application/x-web-app-manifest+json
  • XML 文件:application/xml、application/atom+xml、application/rdf+xml、application/rss+xml
  • SVG 文件:image/svg+xml;

GZip 对基于文本的内容的资源压缩效果最好,在压缩较大文件时往往可实现高达 70-90% 的压缩率,而如果对已经通过替代算法压缩过的资源(例如,大多数图片格式)运行 gzip,则效果甚微,甚至毫无效果。k3N28资讯网——每日最新资讯28at.com

浏览器支持情况

如图所示,目前所有主流的现代浏览器都支持 gzip 压缩,如下图所示:k3N28资讯网——每日最新资讯28at.com

图片图片k3N28资讯网——每日最新资讯28at.com

浏览器在发送请求时会自动请求该压缩编码的格式,如下图的请求头信息所示:k3N28资讯网——每日最新资讯28at.com

图片图片k3N28资讯网——每日最新资讯28at.com

浏览器会自动在请求头(Reqeust header s)信息中添加 Accept-Encoding: gzip 向服务器请求压缩编码格式的文件,gzip 压缩编码格式就在其中。k3N28资讯网——每日最新资讯28at.com

启用GZip

Nginx是否支持 GZip

nginx 中的 gzip 处理模块是:ngx_http_gzip_module。可以使用:nginx -V 命令,查看 nginx 服务器是否开启了对 gzip 的支持模块:k3N28资讯网——每日最新资讯28at.com

图片图片k3N28资讯网——每日最新资讯28at.com

如果显示如上图所示的:–with-http_gzip_ static _module,就说明你的nginx服务器已经支持 gzip 了,可以开始配置 gzip 压缩了。k3N28资讯网——每日最新资讯28at.com

未开启GZIP压缩

模拟网速慢未开启压缩。首先我们对nginx进行限速操作,限制每个连接的访问速度为128K来建立一个比较慢的访问场景。k3N28资讯网——每日最新资讯28at.com

修改mall.conf配置文件,进行限速操作k3N28资讯网——每日最新资讯28at.com

server {    listen       80;    server_name  mall.tinywan.com;        limit_rate 128k; # 限制网速为128K    location / {        root   /usr/share/nginx/html/mall;        index  index.html index.htm;    }    error_page   500 502 503 504  /50x.html;    location = /50x.html {        root   /usr/share/nginx/html;    }}

对mall的前端项目mall.tinywan.com进行访问,我们可以发现网站中有个js文件比较大,需要加载12s。k3N28资讯网——每日最新资讯28at.com

图片图片k3N28资讯网——每日最新资讯28at.com

Nginx 返回请求头信息如下k3N28资讯网——每日最新资讯28at.com

图片图片k3N28资讯网——每日最新资讯28at.com

开启GZIP压缩

开启Gzip模块。在Nginx配置文件中的http块内添加以下内容:k3N28资讯网——每日最新资讯28at.com

http {    gzip on;    gzip_types text/plain application/javascript;}

这里的gzip on表示开启gzip压缩,gzip_types指定需要进行压缩的文件类型,例如text/plain表示纯文本文件,application/javascript表示JavaScript文件。k3N28资讯网——每日最新资讯28at.com

完整配置文件k3N28资讯网——每日最新资讯28at.com

http {    gzip on; #开启gzip    gzip_disable "msie6"; #IE6不使用gzip    gzip_vary on; #设置为on会在Header里增加 "Vary: Accept-Encoding"    gzip_proxied any; #代理结果数据的压缩    gzip_comp_level 6; #gzip压缩比(1~9),越小压缩效果越差,但是越大处理越慢,所以一般取中间值    gzip_buffers 16 8k; #获取多少内存用于缓存压缩结果    gzip_http_version 1.1; #识别http协议的版本    gzip_min_length 1k; #设置允许压缩的页面最小字节数,超过1k的文件会被压缩    gzip_types application/javascript text/css; #对特定的MIME类型生效,js和css文件会被压缩    include /etc/nginx/conf.d/*.conf;}

再次对mall的前端项目mall.tinywan.com进行访问,我们可以发现js文件已经被压缩,加载时间缩短到3.88s,提速3倍左右:k3N28资讯网——每日最新资讯28at.com

图片图片k3N28资讯网——每日最新资讯28at.com

Nginx返回请求头中添加了Content-Encoding: gzip的信息k3N28资讯网——每日最新资讯28at.com

图片图片k3N28资讯网——每日最新资讯28at.com

总结

在服务器端 Nginx 启用 gzip 压缩,对于目前流行的单页面应用而言,起到的前端性能优化作用的意义就更大了,因为单页面应用的界面完全是由 JavaScript 动态绘制出来的,启用 gzip 压缩更快速的加载资源文件,特别是 JavaScript 脚本文件,就能尽快地显示界面,从而提升用户体验。k3N28资讯网——每日最新资讯28at.com

启用 gzip 压缩除了优化了页面的加载速度外,而对于公司来讲,启用 gzip 压缩后,网站对于网络带宽的需求也降低了,或者说是在现有的带宽情况下,能够更加充分的利用带宽资源,从长期效益来看,也可以间接的降低公司在带宽上的运行成本。k3N28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-35290-0.htmlNginx如何开启GZIP文件压缩,你学会了吗?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 利用 Golang 中的 Recover 处理错误

下一篇: pring Boot 统一响应体处理器详解

标签:
  • 热门焦点
  • Mate60手机壳曝光 致敬自己的经典设计

    8月3日消息,今天下午博主数码闲聊站带来了华为Mate60的第三方手机壳图,可以让我们在真机发布之前看看这款华为全新旗舰的大致轮廓。从曝光的图片看,Mate 60背后摄像头面积依然
  • 天猫精灵Sound Pro体验:智能音箱没有音质?来听听我的

    这几年除了手机作为智能生活终端最主要的核心之外,第二个可以成为中心点的产品是什么?——是智能音箱。 手机在执行命令的时候有两种操作方式,手和智能语音助手,而智能音箱只
  • 摸鱼心法第一章——和配置文件说拜拜

    为了能摸鱼我们团队做了容器化,但是带来的问题是服务配置文件很麻烦,然后大家在群里进行了“亲切友好”的沟通图片图片图片图片对比就对比,简单对比下独立配置中心和k8s作为配
  • K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • 一文掌握 Golang 模糊测试(Fuzz Testing)

    模糊测试(Fuzz Testing)模糊测试(Fuzz Testing)是通过向目标系统提供非预期的输入并监视异常结果来发现软件漏洞的方法。可以用来发现应用程序、操作系统和网络协议等中的漏洞或
  • WebRTC.Net库开发进阶,教你实现屏幕共享和多路复用!

    WebRTC.Net库:让你的应用更亲民友好,实现视频通话无痛接入! 除了基本用法外,还有一些进阶用法可以更好地利用该库。自定义 STUN/TURN 服务器配置WebRTC.Net 默认使用 Google 的
  • 东方甄选单飞:有些鸟注定是关不住的

    文/彭宽鸿编辑/罗卿东方甄选创始人俞敏洪带队的“7天甘肃行”直播活动已在近日顺利收官。成立后一年多时间里,东方甄选要脱离抖音自立门户的传闻不绝于耳,“7
  • 华为将推出盘古数字人大模型 可帮助用户12小时完成数字人生成

    在今日举行的2023年华为云数字文娱AI创新峰会上,华为云全球Marketing与销售服务总裁石冀琳表示,华为云将在后续推出盘古数字人大模型,可帮助用户12小
  • 三星电子Q2营收60万亿韩元 存储业务营收同比仍下滑超过50%

    7月27日消息,据外媒报道,从三星电子所发布的财报来看,他们主要利润来源的存储芯片业务在今年二季度仍不乐观,营收同比仍在大幅下滑,所在的设备解决方案
Top