京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 4489|回复: 0

ASP.NET Core文件压缩常见使用误区(最佳实践)

[复制链接]

18

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2021-8-8 05:16:25 | 显示全部楼层 |阅读模式 来自 中国
前言/ j5 E2 Y/ P6 M( P7 v: ?4 s0 R! B
. P2 E; `, q# r- }( Y6 h( Q6 I
  在微软官方文档中,未明确指出文件压缩功能的使用误区。
" h# r; V5 u% z: ?  D# w  本文将对 ASP.NET Core 文件响应压缩的常见使用误区做出说明。
" S- u0 J  {; n: w误区1:未使用Brotil 压缩8 i5 u% |0 ^6 I2 l- \0 N
* {/ I; ]6 s: a8 Q% |* U
  几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
1 C; }" o/ [. S$ w  G6 Y* P  同时启用 Gzip / Brotil 压缩
5 U+ y! V9 b1 n# W, c  Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。% l0 y# q+ v* s0 _$ ~0 Q
  所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
% ]# a5 e8 L0 x1 R  如何区分 Gzip 压缩和 Brotli 压缩+ P! M7 }7 d! f0 o2 {9 ~
  网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。# m2 B3 c4 w+ @
误区2:使用 Fastest 级别的 Brotli 压缩
2 O5 U. `- b, M  |
5 S) O) V+ f: p4 Y$ u  b  如果你阅读并参考了微软官方文档或者其他中文资源,比如:0 W6 h+ Y7 Y) I. T( ~' ^$ N
  ASP.NET Core 中的响应压缩 - MS Doc9 z6 _- G" x9 c3 |4 V
  在ASP.NET Core中使用brotli压缩- Cnblogs+ F( x9 v+ ]* ]$ y% x! t
  那么你可能会在代码中像下面这样使用压缩功能:* g1 m3 Y# A  a: K3 w- n
  写法1:使用默认的压缩行为(框架将隐式添加 Brotli 和 Gzip 功能)
  1. public class Startup{    public void ConfigureServices(IServiceCollection services)    {        services.AddResponseCompression();    }    public void Configure(IApplicationBuilder app, IHostingEnvironment env)    {        app.UseResponseCompression();    }}
复制代码
  写法2:显式添加压缩功能
  1. public void ConfigureServices(IServiceCollection services){    services.AddResponseCompression(options =>    {        options.Providers.Add();        options.Providers.Add();        options.Providers.Add();        options.MimeTypes =             ResponseCompressionDefaults.MimeTypes.Concat(                new[] { "image/svg+xml" });    });    services.Configure(options =>     {        options.Level = CompressionLevel.Fastest;    });}
复制代码
  写法3:自定义 BrotliCompressionProvider
  1. public class BrotliCompressionProvider : ICompressionProvider{    public string EncodingName => "br";    public bool SupportsFlush => true    public Stream CreateStream(Stream outputStream)    {           return new BrotliStream(outputStream,CompressionLevel.Fastest);    }}
复制代码
  不幸的是,以上三种写法都没有发挥出 Brotil 压缩算法的优势。
$ M" T# @, I  X, B  它们的共同点是均使用了 CompressionLevel.Fastest压缩级别。& p, g2 ^9 y" \$ E6 z
  而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。6 q% j  I  h( Z
  参考:Introducing Support for Brotli Compression& q9 O2 U6 t! ]+ c2 L0 @4 K8 s
1 U1 C" g9 D6 Y! a/ ?$ B
图 2-1 Fastest 模式下,三种算法的压缩率等同6 f: t5 |; I/ ?' e) r! `9 s
误区3:使用 Optimal 级别的 Brotli 压缩9 c# B* k" T6 D6 y0 {: t: b

& y  p# |2 O  W; n- W0 b/ J: m  CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。
6 n4 ~! O, r+ ^4 I  l% H  既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
9 b0 F% G8 e% ?, ~& |: k& K8 S; z
4 X' D5 J; i1 N# g1 Q3 m' I
图 3-1 压缩级别枚举
" Y& \; L" z1 d% G  非常不幸,Brotil 的 Optimal 压缩级别存在严重的性能问题,在实际网站应用中几乎没有适用的场景。) y  B2 a! F. ~/ c0 b0 o) S
. j& W% H; |! U  G- i) F! q4 |: O
图 3-2 Optimal 压缩耗时对比: r- B- N+ u. o5 m' h
最佳实践:使用 4 或 5 级别的 Brotli 压缩  W3 u+ I$ ]+ g* Q/ ~

. W' F! p0 c  L. D  在Introducing Support for Brotli Compression这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。( X5 A. L7 }1 o  M9 g1 i- u! S1 V, B
7 N7 X# h0 @7 x4 X# [' a( o
图 4-1 不同压缩级别下 Brotli 的压缩耗时2 M4 |/ u$ Q" ?4 s+ Y3 Z
  观察这副图,Brotil 的压缩质量其实有 1~11 个级别。2 K" X1 _6 N3 z$ H3 E
  那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。  t  y5 Z& I9 q8 k
  参考:Setting a specific Brotli compression level when using response compression in ASP.NET Core7 p7 t; P9 Q5 d) z; @
2 Z: v8 R/ m- w7 Q, v8 w
图 4-2 指定 Brotli 的压缩级别
0 k1 r# S( e" v5 ^4 X' E& j- m/ F  尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
% k8 m' H6 E: L. _  参考:System.IO.Compression.BrotliUtils.cs
: e+ F! G- z8 `7 \* W) u0 S
+ ~7 g0 d" a0 }; m3 n
图 4-3 CompressionLevel 枚举强制转换整数2 A) f0 g2 h2 V, S) W/ V
  现在我们可以自定义压缩级别了,但注意上方源码,只能指定 3 以上的级别,3 包括 3 以下的值有其他对应的转换逻辑。0 @# S( W( v7 b8 y
  回到本节第一副图 4-1,通过实测,发现在 4 / 5 级别下,Brotli 确实可以获得最佳的压缩率和较低的压缩损耗。0 M) C& r9 w; s8 T8 `
总结
8 D6 M# N: X4 M9 [. p9 u5 C
( `& H; h; Q) W1 p2 G3 J! r- Z  在 ASP.NET Core 中,我们应该同时启用 Gzip 和 Brotil 压缩功能,其中 Brotil 的压缩级别应该自定义到 4 或 5。
  1. public void ConfigureServices(IServiceCollection services)        {            services.AddResponseCompression(options =>            {                options.Providers.Add();                options.Providers.Add();                options.MimeTypes =                    ResponseCompressionDefaults.MimeTypes.Concat(                        new[] { "image/svg+xml" });            });            services.Configure(options =>            {                options.Level = (CompressionLevel)4; // 4 or 5 is OK            });        }        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)        {            app.UseResponseCompression();        }
复制代码
以上就是ASP.NET Core文件压缩最佳实践的详细内容,更多关于ASP.NET Core文件压缩的资料请关注脚本之家其它相关文章!" `, ~8 s9 W3 G( V( g, Q, ?7 F9 A
8 F* q) e- B4 P* k7 l9 M& `9 p+ ~
来源:http://www.jb51.net/article/213390.htm! S6 h9 Z* o5 W1 h3 D, k
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2026-4-21 08:01 , Processed in 0.042504 second(s), 24 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表