|
|
目录5 ?9 I1 `9 ~7 e, l
+ f5 H% }: H$ y8 ` s) y# A; P
! ^( a# @ I" S: o ~. i
- 误区1:未使用 Brotil 压缩
0 T1 o5 i' P2 ~; e, r - 误区2:使用 Fastest 级别的 Brotli 压缩
?* I: U8 M: N - 误区3:使用 Optimal 级别的 Brotli 压缩& T K2 Z" D2 t* V& P/ E
z- d& B' G+ n# H3 z. H! i/ A! a误区1:未使用 Brotil 压缩
/ ^, c1 o. `9 V) R% \
/ r& S: _' F6 I2 k* m
* V: G0 X& ?8 i1 ^( M9 q1 j 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。/ f7 O6 i# g) k6 e
同时启用 Gzip / Brotil 压缩, p0 i3 P3 H F7 r: D3 o' l0 `
Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。8 \2 z: \7 ^5 t ?: t, u
所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
& N0 X' b1 }( o 如何区分 Gzip 压缩和 Brotli 压缩+ |3 v' j, Y9 C( a. I# E' w$ a6 s
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
% c ~, X$ d! w* r1 ~( |; @# l: k: p- N. A
误区2:使用 Fastest 级别的 Brotli 压缩
" n) ^, \) Y! F; U
; l% M e# J" Y% ^& q7 A4 b9 m4 Q! i4 x) e
如果你阅读并参考了微软官方文档或者其他中文资源,比如:- W2 u+ Q, e8 u, y( x7 t
ASP.NET Core 中的响应压缩 - MS Doc9 ]1 {9 Q7 [) ?
在ASP.NET Core中使用brotli压缩 - Cnblogs4 ]+ y9 W% ?; ~$ g4 j% o
那么你可能会在代码中像下面这样使用压缩功能:
. d, N8 @( A3 S8 A% i 写法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 压缩算法的优势。. X1 K0 P: X! ?
它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。 Z' D9 M& K, y- q% d' b1 V
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。6 E$ D7 o& c- C# U$ G3 K$ t
参考:Introducing Support for Brotli Compression
- U M+ [8 n* G+ k9 a* I" r5 |3 c, D4 u- f: a6 @
2 C: o: d# ]+ B' K
误区3:使用 Optimal 级别的 Brotli 压缩
& z6 b* X m* N' W0 G7 z. q3 A5 c% s. Q# W" A6 k% a4 Q& z
' q ]3 J& [" `6 i* W6 T& I. B CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。
' a9 u+ x1 @+ Q4 O 既然 Fastest 级别没有用,那我们只能换成 Optimal 了。( v7 t# o# t9 f) ^0 V; `6 r" |2 L' `
* K* K5 O8 M$ D) ^& y* N' A
( c. M2 H4 L' ]8 B# u1 O8 r最佳实践:使用 4 或 5 级别的 Brotli 压缩7 u( M; q: ] T; t& N+ N3 r0 M
在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。
1 `4 `+ z+ B5 v+ e( F; y0 X0 Y6 X l8 Z6 J. Z; U; H6 k! P
观察这副图,Brotil 的压缩质量其实有 1~11 个级别。
# @4 W) g: o6 C: ^9 M+ p 那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
( T. K0 J9 r3 z+ T3 l% u5 r' _7 ^
1 ^7 V9 J5 {( ]2 ` 尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。5 ?1 {/ J+ t; m- P5 ~7 J1 d6 B8 L
以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!+ y4 ~+ p$ t5 e g9 V
1 K7 k0 O8 t5 l
来源:http://www.jb51.net/article/213748.htm
4 z$ ^$ z9 l( R$ }9 T免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|