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

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 4435|回复: 0

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

[复制链接]

18

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2021-8-8 05:16:25 | 显示全部楼层 |阅读模式 来自 中国
前言9 N  a# @$ k- F- h6 g* y( S2 g% R
; q. r* B  G+ n4 c& J" p7 F4 m
  在微软官方文档中,未明确指出文件压缩功能的使用误区。
; ?, k" k5 J( w# X0 u  C& r  本文将对 ASP.NET Core 文件响应压缩的常见使用误区做出说明。
. P' j1 Q6 T7 g( b/ j误区1:未使用Brotil 压缩
8 u2 P! L* ]0 i  X. [; O) `. x. ^+ ^2 j
  几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
5 B% }# D$ `# G. h  同时启用 Gzip / Brotil 压缩+ C  W5 ]& Z7 b' w2 ~# U+ P. w# z* l
  Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。
& Z2 K" x" q3 D3 b  所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
3 D. O0 W) L/ `1 n; \  如何区分 Gzip 压缩和 Brotli 压缩2 i+ [) S" b+ R- l
  网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。$ T0 [, `3 i1 ]" L
误区2:使用 Fastest 级别的 Brotli 压缩' h3 b! d3 i  x6 d

0 b7 e$ @. k9 s. c% `+ ]  如果你阅读并参考了微软官方文档或者其他中文资源,比如:2 e1 O: Y+ \* s6 A* G( l
  ASP.NET Core 中的响应压缩 - MS Doc0 @6 b* `% a  I7 Y# o+ {
  在ASP.NET Core中使用brotli压缩- Cnblogs
' y2 k1 Y: G+ Y5 r) p6 C. s2 L6 ]5 ?: q6 F5 O  那么你可能会在代码中像下面这样使用压缩功能:
5 i# _) m( a6 d4 |  写法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 压缩算法的优势。
, P  |  N& J* n! _: |7 e  它们的共同点是均使用了 CompressionLevel.Fastest压缩级别。; C; R- A# i, v9 d- N# S
  而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。2 f' z0 r% e! H' y- _! J9 q. d" Y8 T
  参考:Introducing Support for Brotli Compression9 ^, Q3 a& Y( [8 q" X

* I' ]: T8 B) U+ U4 I; _0 e! N( ]( G图 2-1 Fastest 模式下,三种算法的压缩率等同  d% Z( a; w# N$ k1 ^0 D2 z
误区3:使用 Optimal 级别的 Brotli 压缩
- z# {. t/ x7 }* _; e6 N, M& F
9 Z3 c8 z7 q8 G- }( S) y  CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。; ^& k. c! j0 a- ~3 \
  既然 Fastest 级别没有用,那我们只能换成 Optimal 了。: \$ J$ R9 [' A! A
' b( @' {/ H6 N! C% J
图 3-1 压缩级别枚举
/ n% G& }$ \, \& g  非常不幸,Brotil 的 Optimal 压缩级别存在严重的性能问题,在实际网站应用中几乎没有适用的场景。0 k. ~% b2 P/ i" N! ]) _

  q$ w/ Q' e6 ~$ h* `图 3-2 Optimal 压缩耗时对比
# B, a, ?  [2 n最佳实践:使用 4 或 5 级别的 Brotli 压缩
' Q/ l% i% N! J& u' X% N. U) K4 |% m1 J3 q6 |9 H' o
  在Introducing Support for Brotli Compression这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。
( H: E" c! b% A7 v5 B: o# a0 Y2 O
) U, S: D! ~/ D  K" f* X  S% T
图 4-1 不同压缩级别下 Brotli 的压缩耗时3 l7 i5 e9 w; H5 h/ K$ j4 ?
  观察这副图,Brotil 的压缩质量其实有 1~11 个级别。
0 b3 N& L  q: H1 ~9 O/ z  那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
' t! S) q7 O1 S3 M  参考:Setting a specific Brotli compression level when using response compression in ASP.NET Core
9 S" l# c! ~% e

8 ?& `$ k* y  D+ U; {5 L* w3 h图 4-2 指定 Brotli 的压缩级别
1 u8 d1 Y+ F0 v2 @% y/ m' h  尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
& F* k  p% |; N1 b  参考:System.IO.Compression.BrotliUtils.cs) p7 k; y$ p& l
( |- n7 m4 g- M: e* n8 t
图 4-3 CompressionLevel 枚举强制转换整数
$ X) O" `# T/ ^/ }  o5 z$ n  现在我们可以自定义压缩级别了,但注意上方源码,只能指定 3 以上的级别,3 包括 3 以下的值有其他对应的转换逻辑。1 X- R4 m) P8 c8 Y/ i% S! S
  回到本节第一副图 4-1,通过实测,发现在 4 / 5 级别下,Brotli 确实可以获得最佳的压缩率和较低的压缩损耗。
9 W, h% N! l" \- b4 x, D% k总结6 f0 p. x3 x  _0 m* S2 S$ e
0 {) e4 ~3 [% P5 ^! I& q5 s
  在 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文件压缩的资料请关注脚本之家其它相关文章!0 r4 H: a7 }3 Z: e$ R. T- [) e' P0 g0 u
  J$ c( o7 y8 k/ J: n
来源:http://www.jb51.net/article/213390.htm# r: D' |, _6 a) E* j' J0 B
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

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

×

帖子地址: 

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-4 04:11 , Processed in 0.037094 second(s), 23 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

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