|
|
目录
6 Z) X. p4 K# s4 @# n0 A r5 U, \; F/ w' {# x+ k8 y7 S- E, V
# f! g3 i& w s8 c
- 误区1:未使用 Brotil 压缩1 Q7 J" G) L" F# |3 c
- 误区2:使用 Fastest 级别的 Brotli 压缩
5 B8 U( s1 F0 J% x - 误区3:使用 Optimal 级别的 Brotli 压缩
% } O, I, q! }) x) v$ K) q
# N9 j5 z+ @8 Q2 f# j1 h2 x6 @( t/ X误区1:未使用 Brotil 压缩
# `* Y6 Z5 g4 v3 [2 B- r4 K; M
, q6 x) L5 p! t
1 s- l5 c! t9 P$ M2 Q: K5 t 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
1 t! }4 y9 {( W8 d: X" ?9 h% }7 u 同时启用 Gzip / Brotil 压缩8 A, s! H! Y& |1 o: `
Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。
( F6 A6 S5 ~+ C; K 所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。" _. ]" o* E' V& v0 P; ]; Z
如何区分 Gzip 压缩和 Brotli 压缩1 ~- Q1 i3 y& G6 o# }! X
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。* J' _0 H4 ?; ?1 U" p% a; |
1 O7 w2 |! X) Z6 U/ l误区2:使用 Fastest 级别的 Brotli 压缩9 i6 s z# p+ [7 d+ u9 s# G
+ `. d- d7 w5 U/ X4 x6 i
, Q9 E# y, C( G5 ~, J
如果你阅读并参考了微软官方文档或者其他中文资源,比如:$ J$ [9 L4 A7 O6 k; Y( E
ASP.NET Core 中的响应压缩 - MS Doc% W+ R# _9 u7 p1 \
在ASP.NET Core中使用brotli压缩 - Cnblogs3 c" F, Z; ]& i* L% r6 ^, f/ W
那么你可能会在代码中像下面这样使用压缩功能:$ ]$ `7 i% d. H. 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 压缩算法的优势。
5 A3 c- [2 s" X 它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。 ]( i8 |0 f; ~1 C
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。
% i! H# X' B4 S, u4 ]% D, G) K 参考:Introducing Support for Brotli Compression
/ u/ }' D/ e" Q
- T. a6 C- ]3 ^7 P+ D! c% B' p0 x4 G4 x0 b3 a
误区3:使用 Optimal 级别的 Brotli 压缩
. v' _+ Y2 U' k/ g! F' ^5 t& U& [) J2 h% b( s: w" w
7 E- F. z" q" z1 G# y0 H+ [
CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。! H- O S% v u8 f) g
既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
7 B d) y" Y; A+ @0 w o4 ?& n0 p7 C$ B$ }
+ O$ p/ i; B; v; @
最佳实践:使用 4 或 5 级别的 Brotli 压缩
) m# W3 K" W4 t4 o0 {& @" b/ C 在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。
' b& p$ I: D$ k, r$ o6 x0 ~& B/ q! @: O/ R
观察这副图,Brotil 的压缩质量其实有 1~11 个级别。
3 @$ ]( Y3 n4 ` 那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。9 n2 D' l7 g: o; h
- B$ N2 B8 B/ \6 S0 h5 K
尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。
7 X5 f- b, g/ x; N5 m }9 q以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!
8 R7 F+ m, W: a7 l$ L' B- S$ a7 q: L# y( p6 i' f2 I4 R# v! B F
来源:http://www.jb51.net/article/213748.htm
) H- F4 y: E+ E! M2 A0 B' U$ p免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|