|
|
目录: w& `& n$ a7 S% r3 |0 C* @( t
9 p" J4 y9 i$ n. F. ~. V: x: w/ V3 M6 K( m5 ]
- 误区1:未使用 Brotil 压缩" o. @7 b. Z/ `: j
- 误区2:使用 Fastest 级别的 Brotli 压缩$ u. ~8 A4 z! D# [; b2 X
- 误区3:使用 Optimal 级别的 Brotli 压缩+ a# p5 v9 W- X; ^
9 U! `6 Z6 j, F; @* I. J误区1:未使用 Brotil 压缩
* z' N3 q( f. z& L+ }4 [' @$ W- }; w% a1 D+ O+ n! ]. A% f
# D; f" W: l* G% V' R1 C
几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。7 K% o1 k7 @/ r U
同时启用 Gzip / Brotil 压缩. t7 r6 F$ D$ D5 R+ s
Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。( l3 E- i1 a. d) G* R9 k
所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。7 v$ I- Y) L/ o6 w, `$ Y0 w: J
如何区分 Gzip 压缩和 Brotli 压缩0 M7 ]2 I2 {' L7 { T
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
( @4 u8 _5 {/ |; B
$ ^- e% p& e0 H误区2:使用 Fastest 级别的 Brotli 压缩
" y# n! Y+ p& j3 R2 v+ Q. r
9 `" N& g, J) x# I; }# o
3 L! Q& Q0 p$ e 如果你阅读并参考了微软官方文档或者其他中文资源,比如:3 _6 |6 j7 h: u( p' l! O7 B
ASP.NET Core 中的响应压缩 - MS Doc0 O. @7 W7 e) O/ t
在ASP.NET Core中使用brotli压缩 - Cnblogs/ I! [: v @5 H1 k/ L+ p- g* _. _9 r
那么你可能会在代码中像下面这样使用压缩功能:
# y d9 D; @( P; @) p1 S- C1 s 写法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 u y b8 W7 j4 A 它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。# l w, v8 e' W- f4 _
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。( l. M* N( k* ?3 V) t; l$ l2 u
参考:Introducing Support for Brotli Compression
' c/ I: ^5 P1 E% ]$ K' E* H$ J# e( D6 v: X% L7 I
2 k: d; L# d: ^& a" f2 z: j误区3:使用 Optimal 级别的 Brotli 压缩7 K+ o. c- b( g
% p% u8 Z6 ~. h O7 j6 U8 ?6 H" @
8 A1 m+ [6 y1 G: y CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。" i+ O) |9 K7 y* z& Q- y
既然 Fastest 级别没有用,那我们只能换成 Optimal 了。. `6 @0 Z8 r& f! G! v _0 n
% V* O( M9 e! H4 ]9 O
; K( I- [$ i/ i7 C: n; U5 A2 P( F最佳实践:使用 4 或 5 级别的 Brotli 压缩
. P$ n7 N( v. B& ^8 ^ 在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。( a# s5 J* X5 _, R# S# r
3 b0 B# N8 T( A d. o: n0 T% j8 W
观察这副图,Brotil 的压缩质量其实有 1~11 个级别。
2 J# [# i3 K0 u- d 那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
- V+ w# m7 K2 x8 F# J5 a & T7 m( }6 s- N. d5 G
尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
7 z# U) }5 }1 ^, t& h0 [) U7 A以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!& D6 t( u( m1 l2 {" n- u$ y; j
2 h5 a9 M0 l$ r; j) g' h
来源:http://www.jb51.net/article/213748.htm1 [8 o8 ?. E: ~$ U% a
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|