|
|
目录
+ |$ b& a9 D: x y( e4 C3 p6 \- U
# K$ q+ J8 H# f. d1 L
- 误区1:未使用 Brotil 压缩" R$ q! s8 ?. {; W
- 误区2:使用 Fastest 级别的 Brotli 压缩5 r4 n. v5 a# N2 c8 [- _/ `. G _# }
- 误区3:使用 Optimal 级别的 Brotli 压缩
$ ~" C4 ^) o& D) J6 U3 g 7 b) e8 [$ C) T$ n& {- d
误区1:未使用 Brotil 压缩
# m i- j* |7 r" Y3 Q
}2 l: U( Z: H$ J4 n. w
, H K; r3 C( E; w4 v$ i 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。2 h4 l/ U5 a2 h" j' W8 p3 C
同时启用 Gzip / Brotil 压缩
2 t5 A2 T( j, k3 G8 B Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。
" I" y! I" ^ F/ n' A 所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。
( a' b; p* y/ i8 m" v" f 如何区分 Gzip 压缩和 Brotli 压缩' n: P1 l" s, j
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
' B9 L. p! j5 j2 a" M/ \$ ^* P9 X3 f* J4 f; T) S* P+ G
误区2:使用 Fastest 级别的 Brotli 压缩
8 b' ~. ?( @! L( D* a
) d. p4 T- K2 q5 z# W8 W$ R9 f" U4 ^' Y/ i3 s( a. [
如果你阅读并参考了微软官方文档或者其他中文资源,比如:
e! G/ L; Y/ v7 Y) W/ [, h, T ASP.NET Core 中的响应压缩 - MS Doc2 X' v% T4 V5 P5 j# D
在ASP.NET Core中使用brotli压缩 - Cnblogs
6 R, z, i$ n2 f. e% M) B 那么你可能会在代码中像下面这样使用压缩功能:
2 h2 Z$ [4 s6 `8 v- D 写法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 压缩算法的优势。- G% H0 \7 ~0 T; J6 s# P0 S$ S5 b: j" m
它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。9 s" [. F) F, W& K7 x1 |
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。) N& E" U- }% D+ z' C& T
参考:Introducing Support for Brotli Compression
0 s; ^! R. N; `1 p+ y D
5 B4 ~! @7 q9 O& K! s( p$ I7 V& v
误区3:使用 Optimal 级别的 Brotli 压缩1 R5 Q, i! f" T% P) S( M; W
( x6 c) L [# V6 }. Q6 Q: ^. b6 p6 d% ~
$ o1 y; x |6 R6 O5 u" I CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。
J$ H; S$ u& R! k/ T1 E& { 既然 Fastest 级别没有用,那我们只能换成 Optimal 了。* N& t: T' b0 A8 x, x U
# g q( f1 F7 F
, ?3 v* F8 T7 S5 _8 l x
最佳实践:使用 4 或 5 级别的 Brotli 压缩 v* S5 B4 F( B# C0 X7 v0 Y" ~
在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。4 T, h) I! T9 z
! T5 O- h2 x# q" b8 s' d
观察这副图,Brotil 的压缩质量其实有 1~11 个级别。
) ?2 a9 r" C1 L6 z) I 那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。
1 @! @& ~3 E9 u5 \) y5 E
9 f0 x1 G& e0 X ~6 L* J2 t7 v9 k 尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
/ \/ |' i3 |; t p% x. g8 A- p以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!
2 \5 w" A$ r- E8 N9 A0 |. V4 a9 x4 k, f* K8 q# e
来源:http://www.jb51.net/article/213748.htm
3 O2 Q1 O) F y( Y免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|