|
前言
9 J. D. ^6 O: i& e; g) w6 S Y
8 ^$ Q T- L1 O& x 在微软官方文档中,未明确指出文件压缩功能的使用误区。
7 ?8 y3 s2 P; y: _% J; L 本文将对 ASP.NET Core 文件响应压缩的常见使用误区做出说明。1 E6 u h9 M" \
误区1:未使用Brotil 压缩
' r6 A. L, Q9 p
5 \; E( W9 J* y+ @ r. V 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
/ r2 f! B! u# v* Y/ \4 S! } 同时启用 Gzip / Brotil 压缩
1 b5 T- d4 d0 k0 h* w Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。
m% G* d" @7 p+ F. l 所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
" {. \5 Q' R0 {: l* c; o 如何区分 Gzip 压缩和 Brotli 压缩$ k% w: E( O" ]3 u% [( b0 y
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。3 [1 y2 a6 _2 }
误区2:使用 Fastest 级别的 Brotli 压缩+ U C+ F) f ]4 I
( W& C( t4 ]0 x) p$ z: H3 d 如果你阅读并参考了微软官方文档或者其他中文资源,比如:
& s6 n* {! O4 Q0 C ASP.NET Core 中的响应压缩 - MS Doc
. o! w- P% j; f/ y6 L 在ASP.NET Core中使用brotli压缩- Cnblogs( e. t' D& w( V$ E; ~; L
那么你可能会在代码中像下面这样使用压缩功能:
( p0 U( e" M/ |/ g 写法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 压缩算法的优势。% k+ p) O# i, `7 M
它们的共同点是均使用了 CompressionLevel.Fastest压缩级别。
9 L6 c- ]& W7 @" k3 ` `7 y% a" p 而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。
( n- y; V3 }- T0 P 参考:Introducing Support for Brotli Compression1 P8 @* h( }1 ]3 q
% E, b% A+ ~6 ^9 W4 h* H4 T图 2-1 Fastest 模式下,三种算法的压缩率等同
- l2 s: I0 e2 I9 A; W1 W3 [# m7 z误区3:使用 Optimal 级别的 Brotli 压缩' E2 c3 H4 j9 r/ w
* k0 w7 ~$ H- k
CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。
2 h" t2 v3 E3 z+ F4 ~7 l 既然 Fastest 级别没有用,那我们只能换成 Optimal 了。% u1 v* w& {: }) P- b
: W8 G. h. {3 R
图 3-1 压缩级别枚举- `. D( P% Y) Q! A, o: P
非常不幸,Brotil 的 Optimal 压缩级别存在严重的性能问题,在实际网站应用中几乎没有适用的场景。
- G" a* ~) x) E. y- z$ J+ A! g7 q# r0 ?, @6 S" K
图 3-2 Optimal 压缩耗时对比
9 r0 P9 {* Z' u# \# T( d- M2 ?最佳实践:使用 4 或 5 级别的 Brotli 压缩; G$ a( q/ K& R0 t+ L9 [+ I
& a% y- O4 g) U; k
在Introducing Support for Brotli Compression这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。* B. [1 c/ ~; V% n. S: X
) N7 e$ a" C- H6 y
图 4-1 不同压缩级别下 Brotli 的压缩耗时
; |, k3 i. y# S 观察这副图,Brotil 的压缩质量其实有 1~11 个级别。1 R' O- `" v' s8 k
那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
% L$ n* X! t+ i/ \2 Z+ s) W3 i 参考:Setting a specific Brotli compression level when using response compression in ASP.NET Core" y1 |' x- Z" ?* _) i
# w6 n( ]$ P0 A/ ^) |% C6 Z
图 4-2 指定 Brotli 的压缩级别
6 ?( X4 l/ u3 } 尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。- f2 g& `3 r2 Y- \
参考:System.IO.Compression.BrotliUtils.cs0 ]+ y6 o: X) v2 W; {" D
z' Y, S% i) R/ d" K) x- F图 4-3 CompressionLevel 枚举强制转换整数
4 W* f9 e$ U7 ~- L( |& O 现在我们可以自定义压缩级别了,但注意上方源码,只能指定 3 以上的级别,3 包括 3 以下的值有其他对应的转换逻辑。3 y/ L& a) c8 \$ K4 h4 W, t0 g4 W3 S5 b" ^
回到本节第一副图 4-1,通过实测,发现在 4 / 5 级别下,Brotli 确实可以获得最佳的压缩率和较低的压缩损耗。0 ]) N2 u9 F5 g4 ?, x
总结
5 A0 ~ g1 ~/ d( p- y4 K
5 r0 b+ C2 T, N0 ]8 g 在 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文件压缩的资料请关注脚本之家其它相关文章!, B9 B$ Y; L% l3 _
; r9 C: O0 }6 |9 H5 w3 x/ H
来源:http://www.jb51.net/article/213390.htm1 l. ^8 Z3 [1 g8 |2 ^
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|