|
|
目录
) }* s- O' v+ P+ `, @* Q
( V" f" _2 r. u& b+ L" W1 J+ w4 z9 V/ h# `: p* ~+ L) m
- 误区1:未使用 Brotil 压缩
! f9 _2 p! Q8 R( x - 误区2:使用 Fastest 级别的 Brotli 压缩
# o0 g& h9 S& V# k( T$ f6 _) p - 误区3:使用 Optimal 级别的 Brotli 压缩8 a" o; I" W3 J0 J$ q5 s
( k. A5 c7 ~3 p7 P- \! u误区1:未使用 Brotil 压缩
) _: H- a/ z* E
5 ?2 H! O* I+ J, b
% F% \* R7 h& ~5 v" T. @: B- g6 C! u 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
- c0 A; @" {, | `7 U 同时启用 Gzip / Brotil 压缩
8 v# f. I( `0 r Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。; v% u4 V1 E9 C2 {; n! d/ M0 O& z
所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
" L+ ~. w* _/ H4 u' I- Y 如何区分 Gzip 压缩和 Brotli 压缩
0 f( d& s" ~3 b& D, a 网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
: I; L# J! {" a/ s( x
& ?. q% E0 b. p$ j1 i8 f" ~误区2:使用 Fastest 级别的 Brotli 压缩: _2 [! e7 \* b/ o: `* U" l) A
: c0 K9 `9 X* Y0 K& z$ d9 ~% C
1 w. f; u* e8 A; T 如果你阅读并参考了微软官方文档或者其他中文资源,比如:
" Y- q; N/ b9 y# R% U ASP.NET Core 中的响应压缩 - MS Doc9 K3 C8 [4 [% E( B: R' D" Q
在ASP.NET Core中使用brotli压缩 - Cnblogs' ^0 d! o9 E, j- I9 j8 L9 O
那么你可能会在代码中像下面这样使用压缩功能:( g1 a- [2 t! T4 E1 y, `
写法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 压缩算法的优势。' Q6 k% ]3 ?$ @9 W5 Y% v! K& f
它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。
0 `6 v w; p( A: ~; A& Y; { 而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。% _& q+ P& p5 E. x6 T! O
参考:Introducing Support for Brotli Compression' I# N. q" S9 b$ v+ M8 O! g
6 l1 l. I' b2 t$ d1 M% `
; b9 v7 h$ ]; K! L* a5 u4 i: ]
误区3:使用 Optimal 级别的 Brotli 压缩; @& w8 z# p, h" v5 C
! N1 D1 z+ H# G% ]+ h( K
7 U3 q$ ?( s4 q CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。/ R3 }' @ i0 c
既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
# O% X) e5 h. C, @9 E# {8 {
. k7 | T4 p" K3 P6 i- M3 |8 e; N% r8 N* ~
最佳实践:使用 4 或 5 级别的 Brotli 压缩9 ]! _# I, I* ~3 N2 ?/ g
在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。. R% J) ^. b. i6 @ ]
|8 ]! M( x8 L9 K9 n# V: e6 v 观察这副图,Brotil 的压缩质量其实有 1~11 个级别。6 B+ f. b5 _* B( X, C
那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
; f3 O, W" P( _' b+ v' E( ^ k% v
8 Z" U! v' ~# }$ T5 i 尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。7 ~8 d8 |- k; S$ E+ P
以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!
1 d% {: F" r* y& o/ J% `$ I0 Y$ e
来源:http://www.jb51.net/article/213748.htm
2 x" I; y; e" L3 C2 H/ J5 j% V免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|