|
|
目录! E3 P: @9 ]& I& I1 I/ d; ~
& z9 s/ @ G+ n6 C W! g
. D( V6 S0 R+ |4 n) B7 m- 误区1:未使用 Brotil 压缩
* K7 {) [) ]2 p - 误区2:使用 Fastest 级别的 Brotli 压缩. B6 u5 w, ?# J
- 误区3:使用 Optimal 级别的 Brotli 压缩! w/ Z Z8 I$ i. k9 g% A3 Y5 F
% e5 \9 n' C$ j5 o) y7 d误区1:未使用 Brotil 压缩
4 y9 ]! t; C N7 {- d) V1 u) t5 h% ?$ P: p. E! A$ @3 w
; _- m- \6 Z9 F4 z( a 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
! |+ k! w' N2 J1 |3 y7 X! y8 r$ s 同时启用 Gzip / Brotil 压缩
% D" W8 G& l# y Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。9 |" h5 L. M5 X* o! U0 {
所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。8 g) R$ c4 G* p
如何区分 Gzip 压缩和 Brotli 压缩) h1 V2 E! J7 {1 [# ~1 j9 [
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。, Q2 }5 Y8 Q6 f) m) h
7 O: x' x' w4 R/ e
误区2:使用 Fastest 级别的 Brotli 压缩
9 B- Q% e/ z% @7 z0 A! t( I4 H
4 e! v) M( ~% q5 j/ r7 c: U1 s* C* _6 N: z
如果你阅读并参考了微软官方文档或者其他中文资源,比如:
5 ^6 a7 D" n9 x4 a ASP.NET Core 中的响应压缩 - MS Doc
, W4 I) t0 Q1 G% Y 在ASP.NET Core中使用brotli压缩 - Cnblogs
9 ?5 }2 D- T" S. @6 k7 S- r 那么你可能会在代码中像下面这样使用压缩功能:+ o" I0 d1 E) R7 m
写法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 压缩算法的优势。/ b* Z( M( r2 f
它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。0 m+ T6 t3 `4 @9 j
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。
/ M3 n( w$ a/ U/ b3 ?+ ~ 参考:Introducing Support for Brotli Compression9 m7 T9 `( G8 g2 T' x
: P' b N! D9 H$ i) I" A3 c
$ X1 N2 _4 w6 K# u% ^4 V `误区3:使用 Optimal 级别的 Brotli 压缩8 z; F2 `4 i$ b+ i) I: _
/ D9 Q; C [3 N* A: ^% N
& k) ?1 m: v' b5 k# w4 P; i$ _7 g CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。$ J2 u/ j+ N" ^; Z$ \
既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
/ c8 i! C+ L0 S1 F) [8 \
7 E0 J+ j+ _/ L# F& z9 u
+ A' K# f, u2 f9 o最佳实践:使用 4 或 5 级别的 Brotli 压缩
' U6 H A4 [2 U5 _9 h2 l 在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。
$ s; G- k1 w" E3 L7 e* c0 i& [! ]6 ?3 ]& k: j3 q3 |4 e
观察这副图,Brotil 的压缩质量其实有 1~11 个级别。! i3 Q$ S, k! F
那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
, l1 u# X$ ^. y5 q7 c
* ?8 B/ i) }2 H1 C; } 尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
# D7 R; F5 j& ~5 o7 ~3 }$ f" I以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!
4 `! m4 M* ^# J7 u7 a4 o. k% j$ `" ?' b! n3 K
来源:http://www.jb51.net/article/213748.htm
3 m9 Q, _# {; {6 X5 h免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|