|
|
目录5 r2 [; I8 `- b
7 K6 a. S* e0 A2 f( [% q, E$ _2 E. @' i- o% i1 F8 ~
- 误区1:未使用 Brotil 压缩* B$ m0 Z4 t B1 S# F' [3 y
- 误区2:使用 Fastest 级别的 Brotli 压缩
3 X! O/ _" m2 g9 g' k1 W" }/ ?4 m - 误区3:使用 Optimal 级别的 Brotli 压缩3 {( @8 \6 {% Q5 B, K
! F! a$ b. j+ Y) b, q误区1:未使用 Brotil 压缩
" d* r) M& B0 {
# f. u' x/ l3 w4 U" a9 ] C# f
几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。0 n; g8 K- G& X: T/ U2 c
同时启用 Gzip / Brotil 压缩+ q! @9 H% r! Q1 I% m
Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。( L5 T. c" |' I3 G* a4 M+ y' L
所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
$ `3 B b% b9 E5 c. z. o 如何区分 Gzip 压缩和 Brotli 压缩4 |# {/ w, A, O; ]8 d
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
7 U# ~# T; }: k& p3 H. u5 h& W
* S J$ _. k" S误区2:使用 Fastest 级别的 Brotli 压缩9 T' J; s7 W! z) A, N
[2 \; w* E( u6 @! h
( P$ N8 l2 v/ B' q5 X/ P3 O1 X 如果你阅读并参考了微软官方文档或者其他中文资源,比如:5 G; Q* S! n& N' {5 S% {+ l% u: Q
ASP.NET Core 中的响应压缩 - MS Doc; Q+ t4 q4 {: e: h2 H6 b% o
在ASP.NET Core中使用brotli压缩 - Cnblogs9 d1 G% S4 F# q( R
那么你可能会在代码中像下面这样使用压缩功能:
. K) F7 \9 Y! }, \/ v5 }# @ 写法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 压缩算法的优势。
! p4 P, A1 e% J( [; u 它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。2 B# w1 ?; c2 O* m
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。
# B, ]( x k% I7 O 参考:Introducing Support for Brotli Compression+ `. [# P- _; q+ w- j+ T$ p
0 U' ^) \ X8 R8 F. O/ m+ l
3 u4 m2 W" G" B4 o+ R% ?误区3:使用 Optimal 级别的 Brotli 压缩
' }% k7 z, ^, Z* k4 @9 b
x0 \. \8 ]- {8 a8 b3 {0 I) Y) G, c& W/ L8 w
CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。
' d. ~. U/ F: ^8 X% B: Y7 ~ 既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
# y2 l! l" r0 U- l
9 V8 u* @. Z1 R ^& J' j& Y6 z W& M
最佳实践:使用 4 或 5 级别的 Brotli 压缩/ o8 q# X. I! j+ v3 j
在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。, ?! {6 N: y( |
/ F( i, e7 ?% h" n+ B- r
观察这副图,Brotil 的压缩质量其实有 1~11 个级别。
9 Y+ g' G% w" V2 K& t4 x/ } 那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
: O- x7 R2 h. e& ]( [- V0 v& v& Q7 } ( m) Z1 Q2 K1 |( @; T2 s
尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
$ ?0 A# {2 Z) E( H以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!/ {0 B5 ?- Y# l N$ x4 M7 U
7 h5 v$ e/ D- Z2 x7 D" B$ q" A4 S
来源:http://www.jb51.net/article/213748.htm4 ^0 L& q8 j4 H" a- R
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|