|
|
前言# t9 z; i- }% S4 H
, v w. _: b6 W( Q, T 在微软官方文档中,未明确指出文件压缩功能的使用误区。9 E6 Y4 p! h! r9 B1 g6 j" A
本文将对 ASP.NET Core 文件响应压缩的常见使用误区做出说明。! V) q7 T0 z$ n9 S
误区1:未使用Brotil 压缩4 h' I* w& W' h& F' Q% R+ e
; P( K" N3 K! t, z 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
: }6 v, ~% N1 j6 U; W$ n 同时启用 Gzip / Brotil 压缩# P2 y) G3 a: ^* T
Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。- d7 u3 e# w( z* L; _$ y9 \% A
所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
# k) t- j3 B. d, s( _ 如何区分 Gzip 压缩和 Brotli 压缩
4 L- ~) M/ [! r) M5 l8 m$ D 网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
; z! L0 h/ S- M: v* q3 O# s% Y误区2:使用 Fastest 级别的 Brotli 压缩/ }! [8 V3 n" w7 w/ X
" K, q8 l) D3 u9 j- K; X
如果你阅读并参考了微软官方文档或者其他中文资源,比如:
; O7 c3 y8 e0 Q ASP.NET Core 中的响应压缩 - MS Doc
& N6 F, E* X- g: z. _ 在ASP.NET Core中使用brotli压缩- Cnblogs
/ ]: Y+ W y# y3 P; F 那么你可能会在代码中像下面这样使用压缩功能:
, B0 f! V$ F/ p( h/ v* I( K 写法1:使用默认的压缩行为(框架将隐式添加 Brotli 和 Gzip 功能)- public class Startup{ public void ConfigureServices(IServiceCollection services) { services.AddResponseCompression(); } public void Configure(IApplicationBuilder app, IHostingEnvironment env) { app.UseResponseCompression(); }}
复制代码 写法2:显式添加压缩功能- 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- public class BrotliCompressionProvider : ICompressionProvider{ public string EncodingName => "br"; public bool SupportsFlush => true public Stream CreateStream(Stream outputStream) { return new BrotliStream(outputStream,CompressionLevel.Fastest); }}
复制代码 不幸的是,以上三种写法都没有发挥出 Brotil 压缩算法的优势。
1 O9 m2 e( I1 ^2 t 它们的共同点是均使用了 CompressionLevel.Fastest压缩级别。
9 x4 t. ]0 O) ?0 d% q$ N 而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。
1 O( b; z g1 d1 Q9 r( X, n, h 参考:Introducing Support for Brotli Compression7 U; P, }- z8 P/ U
! k. `/ t* f% n: ]- O6 F# t3 h
图 2-1 Fastest 模式下,三种算法的压缩率等同& Q0 [& X$ o8 p G" G
误区3:使用 Optimal 级别的 Brotli 压缩
: j: }( M' ~7 \ ?
* Q0 u( }1 _ q4 |' u CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。; W6 o: I( \- P& R3 @" y' [
既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
3 n: X" L8 [' ?1 Y
# K; H j+ w; u图 3-1 压缩级别枚举, G; x! A% W" Q4 m, l
非常不幸,Brotil 的 Optimal 压缩级别存在严重的性能问题,在实际网站应用中几乎没有适用的场景。 @; C G" A0 ^& w2 P
+ j3 R/ o" H& P3 m图 3-2 Optimal 压缩耗时对比
( j. ?3 M( B: ~* N$ M最佳实践:使用 4 或 5 级别的 Brotli 压缩
5 P# \* Z- n" \( M, K2 P
t2 v+ L; Z$ C$ J w! U 在Introducing Support for Brotli Compression这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。2 o6 ^4 ]5 s# U, }. c% q
. |( |! V6 m3 a; \
图 4-1 不同压缩级别下 Brotli 的压缩耗时
; G% v. t8 v: i# k 观察这副图,Brotil 的压缩质量其实有 1~11 个级别。7 x9 d+ I3 f6 k& s% `) F) d
那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。9 V, W' ^0 x! F' h8 G( ?9 W: w- v
参考:Setting a specific Brotli compression level when using response compression in ASP.NET Core
, S; ~5 X& W. ~5 L- Y) T1 m( M, C# u9 R
图 4-2 指定 Brotli 的压缩级别 w8 w' U; X/ r5 _0 ?
尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
- d% q) g) L2 R- [% {0 K 参考:System.IO.Compression.BrotliUtils.cs
) q: f7 _9 s9 U! V2 D2 ?2 F7 v" p4 E. o" P; O8 [* F
图 4-3 CompressionLevel 枚举强制转换整数1 |2 A+ e: v) N1 B4 Z. @' Z5 F
现在我们可以自定义压缩级别了,但注意上方源码,只能指定 3 以上的级别,3 包括 3 以下的值有其他对应的转换逻辑。
+ F& x- E% P7 O1 e% ?9 L 回到本节第一副图 4-1,通过实测,发现在 4 / 5 级别下,Brotli 确实可以获得最佳的压缩率和较低的压缩损耗。* G4 D) B* J) v% A
总结
' [$ D' d9 G, N* s: y
5 t( l2 @* m& k; o& _9 b" t 在 ASP.NET Core 中,我们应该同时启用 Gzip 和 Brotil 压缩功能,其中 Brotil 的压缩级别应该自定义到 4 或 5。- 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 r# |* B$ X: n m. k' H- x$ ~& M4 n
: p; x/ |$ \, F) q2 [0 {+ B来源:http://www.jb51.net/article/213390.htm
! g' q. a( X, v$ c9 ]/ T# o免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|