|
|
目录: T6 F) _ M. E' h
3 R1 G1 B# ?( p* A( O3 @8 p: M1 _, Q# c2 \
- 误区1:未使用 Brotil 压缩1 g Z% z. @$ N7 B
- 误区2:使用 Fastest 级别的 Brotli 压缩
/ C6 n3 @6 T# Z: y/ p! ]- | - 误区3:使用 Optimal 级别的 Brotli 压缩
. u8 ^% d W; F7 {( R$ c5 B: n
4 g+ _: f4 L* w1 ?" E: S误区1:未使用 Brotil 压缩) n9 u! ~# J" g' |! x
! w2 X; A/ z4 ^
- ?7 F1 `1 k7 ?8 t 几乎不需要任何额外的代价,Brotil 压缩算法可以帮助你的网站提升约 20% 静态资源加载性能。
5 ]) E3 U" ]' R* Z' m c- |& x9 u# D( s 同时启用 Gzip / Brotil 压缩
7 T6 u% U/ O& ?6 j Gzip 有更好的 user-agent 兼容性,而 Brotli 有更好的性能。
" B- Q8 [) I. P8 S% n% z2 p 所以我们通常需要在 ASP.NET Core 网站中同时启用这两种压缩。8 t/ E. n1 [8 Y7 ]$ w1 k. a1 m
如何区分 Gzip 压缩和 Brotli 压缩. ~6 L2 E8 }" @
网站启用 Brotli 压缩时,服务器请求返回头 Content-Encoding 中会包含 br 字样,否则是 gzip。
: x% _' |5 C3 {
$ A: Q5 k5 J7 s, O* E8 \- U; B误区2:使用 Fastest 级别的 Brotli 压缩
, m+ k" O/ V j9 {1 b
- k) E6 Z' }# l3 t0 s
! q8 G/ `+ @2 I! I7 j$ b 如果你阅读并参考了微软官方文档或者其他中文资源,比如:1 Y J1 n* w% q6 t$ u
ASP.NET Core 中的响应压缩 - MS Doc8 @7 Y1 f* Y+ |5 M; [/ ~5 u
在ASP.NET Core中使用brotli压缩 - Cnblogs0 o7 d& n. l- E
那么你可能会在代码中像下面这样使用压缩功能:
2 E: s7 l, x3 J8 }0 ]8 [' F4 |$ k 写法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 压缩算法的优势。' r# ~3 |" x) J9 G; B% o; ~+ E6 J" s
它们的共同点是均使用了 CompressionLevel.Fastest 压缩级别。) X5 L" Y* X, {8 J' B! A* _& _
而在 CompressionLevel.Fastest 级别时,Brotil 与 Gzip 压缩性能几乎无异。( }/ ?* r; D# A$ h) \
参考:Introducing Support for Brotli Compression" Z0 w! k- b' w! R
) r' k% f! A8 T) Y' F) k* l$ d5 o; z
误区3:使用 Optimal 级别的 Brotli 压缩
4 ~# B. k l/ D2 j
% D3 N4 c# r) g7 Q6 h3 T
% q$ x+ |* \( N9 j/ W- y CompressionLevel 只有三个枚举值:Fastest / NoCompression / Optimal。" I. G* b3 M+ p% Q" Z; n0 ^
既然 Fastest 级别没有用,那我们只能换成 Optimal 了。
' u: k% r! {" D- U
; B- O/ O- a2 p: I" y( E: r! I& x) ^; i1 \7 J `7 ?4 j% Y% X
最佳实践:使用 4 或 5 级别的 Brotli 压缩
8 m* a# U5 A$ L) d* `! o 在 Introducing Support for Brotli Compression 这篇文章中,作者对不同级别 Brotil 的压缩耗时做了评测,也就是下面这幅图。+ I1 }4 j' E/ {- Z
9 }" G! h7 {6 k 观察这副图,Brotil 的压缩质量其实有 1~11 个级别。
4 t' Y( G+ L3 \0 a 那我们如何自定义 Brotli 的压缩级别呢,答案是直接将级别对应的整数转成 CompressionLevel 枚举。1 b5 q2 h' R! F

) \# z7 y5 P) T* T 尽管这种写法看起来十分古怪,但通过考察 .NET 源码,可以确凿这种写法是可行的。3 Z: M Y, H: }+ o- H9 o& H
以上就是ASP.NET Core 文件响应压缩的常见使用误区的详细内容,更多关于ASP.NET Core 文件响应压缩的资料请关注脚本之家其它相关文章!
* G# Y, P4 h; l9 V( s' T2 h4 W8 {, r' P$ q# E4 z
来源:http://www.jb51.net/article/213748.htm0 e" ]2 a* J' f5 _6 K
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|