|
|
目录
9 p2 b2 M) k( r0 P! N/ u: {% S- U$ [/ B z; C% ?( C) d9 b) x
$ ]* S, |$ R, C- 误区1:未使用 Brotil 压缩
& k- O, o5 |' [) a* ~7 ~- t1 ? - 误区2:使用 Fastest 级别的 Brotli 压缩
! c0 m; {- _3 c, u1 `0 S3 l3 @ - 误区3:使用 Optimal 级别的 Brotli 压缩
+ F$ L w$ Y( R/ N' d1 N9 l( ] q 7 E7 ^: `1 A3 b" |" B& ]: x
误区1:未使用 Brotil 压缩
2 z* }( A* e$ t C7 q2 _0 g. W
, \9 d" X6 X$ _3 v8 B# i8 R# M5 n8 R) w$ S" v
几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。. D* t' T1 p- O4 m2 k
同时启用 Gzip / Brotil 压缩
z* r. W/ c0 o7 h, O Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。5 Q$ y+ e1 m& ?+ ?1 W4 \+ p" Q. H
所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。8 Z3 ]- @6 S0 j
如何区分 Gzip 压缩和 Brotli 压缩
, G% H1 Y0 n% Z 网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
! u4 q5 V2 ]# k" o% ?' R! c' ^4 ]8 a% M0 n
误区2:使用 Fastest 级别的 Brotli 压缩" j( F; Z/ v: M' {! x* t
6 l* U4 D* ~6 L H$ U
8 @6 B' q7 o0 ?' c$ K 如果你阅读并参考了微软官方文档或者其他中文资源,比如:
p" ?# V1 w; s/ h3 J ASP.NET Core 中的响应压缩 - MS Doc% y. b7 G5 k9 Y) Y9 {1 l* n1 C
在ASP.NET Core中使用brotli压缩 - Cnblogs
. }! E* S5 Z/ f% i: v3 y: `4 L 那么你可能会在代码中像下面这样使用压缩功能:
- d9 x) H o/ z9 y% N. m$ }( M3 U 写法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 压缩算法的优势。% ]. [6 ]# c5 c/ G2 b: K/ D0 c
它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。1 O( k6 u: w5 H( N
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。
: c, x) F, e: i9 }. W8 w: F2 p 参考:Introducing Support for Brotli Compression n; s* R3 {/ T9 j
9 B4 |& F ^8 p
/ o, [8 Q, ?6 G
误区3:使用 Optimal 级别的 Brotli 压缩
1 ]2 s$ Z6 h: F$ c- r7 k; ~! V) R$ g. j% L( a3 I9 I* |
; z; w/ q" x& Y" q2 S
CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。8 Q# X( E& f `' ]3 ^
既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
) v. }6 R+ L+ K' S7 r$ e) S- T* N, |! V* t) O
' j2 Y# A8 r& I4 n; i6 E0 G
最佳实践:使用 4 或 5 级别的 Brotli 压缩/ F1 b C5 F# Q& m6 I, O4 q, D1 Y
在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。
; _7 E- _4 a. v% R0 d8 X, i
2 q; a6 [# k; X7 S% S 观察这副图,Brotil 的压缩质量其实有 1~11 个级别。+ `# Y4 f3 A) ~6 |. F
那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
; i& x: F( G- |( ]5 r. ]
- O. G$ a; Z# U+ E S' P 尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。! L* Q, E+ u7 ^
以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!
0 f& R4 x' a! K7 U, {. f. Y8 b9 j* t: _2 A5 g
来源:http://www.jb51.net/article/213748.htm; o9 `! Q `6 T+ `: z( F6 Q
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|