ASP.NET Core 文件響應(yīng)壓縮的常見(jiàn)使用誤區(qū)

asp.net core 文件響應(yīng)壓縮的常見(jiàn)使用誤區(qū)

 

誤區(qū)1:未使用brotil 壓縮

  幾乎不需要任何額外的代價(jià),brotil 壓縮算法可以幫助你的網(wǎng)站提升約 20% 靜態(tài)資源加載性能。

  同時(shí)啟用 gzip / brotil 壓縮

  gzip 有更好的 user-agent 兼容性,而 brotli 有更好的性能。

  所以我們通常需要在 asp.net core 網(wǎng)站中同時(shí)啟用這兩種壓縮。

  如何區(qū)分 gzip 壓縮和 brotli 壓縮

  網(wǎng)站啟用 brotli 壓縮時(shí),服務(wù)器請(qǐng)求返回頭 content-encoding 中會(huì)包含 br 字樣,否則是 gzip。

 

誤區(qū)2:使用 fastest 級(jí)別的 brotli 壓縮

  如果你閱讀并參考了微軟官方文檔或者其他中文資源,比如:

  asp.net core 中的響應(yīng)壓縮 - ms doc

  在asp.net core中使用brotli壓縮- cnblogs

  那么你可能會(huì)在代碼中像下面這樣使用壓縮功能:

  寫法1:使用默認(rèn)的壓縮行為(框架將隱式添加 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<brotlicompressionprovider>();
      options.providers.add<gzipcompressionprovider>();
      options.providers.add<customcompressionprovider>();
      options.mimetypes = 
          responsecompressiondefaults.mimetypes.concat(
              new[] { "image/svg+xml" });
  });
  services.configure<brotlicompressionprovideroptions>(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);
  }
}

  不幸的是,以上三種寫法都沒(méi)有發(fā)揮出 brotil 壓縮算法的優(yōu)勢(shì)。

  它們的共同點(diǎn)是均使用了 compressionlevel.fastest壓縮級(jí)別。

  而在 compressionlevel.fastest 級(jí)別時(shí),brotil 與 gzip 壓縮性能幾乎無(wú)異。

  參考:introducing support for brotli compression

 

誤區(qū)3:使用 optimal 級(jí)別的 brotli 壓縮

  compressionlevel 只有三個(gè)枚舉值:fastest / nocompression / optimal。

  既然 fastest 級(jí)別沒(méi)有用,那我們只能換成 optimal 了。

最佳實(shí)踐:使用 4 或 5 級(jí)別的 brotli 壓縮

  在introducing support for brotli compression這篇文章中,作者對(duì)不同級(jí)別 brotil 的壓縮耗時(shí)做了評(píng)測(cè),也就是下面這幅圖。

  觀察這副圖,brotil 的壓縮質(zhì)量其實(shí)有 1~11 個(gè)級(jí)別。

  那我們?nèi)绾巫远x brotli 的壓縮級(jí)別呢,答案是直接將級(jí)別對(duì)應(yīng)的整數(shù)轉(zhuǎn)成 compressionlevel 枚舉。

 盡管這種寫法看起來(lái)十分古怪,但通過(guò)考察 .net 源碼,可以確鑿這種寫法是可行的。

以上就是asp.net core 文件響應(yīng)壓縮的常見(jiàn)使用誤區(qū)的詳細(xì)內(nèi)容,更多關(guān)于asp.net core 文件響應(yīng)壓縮的資料請(qǐng)關(guān)注碩編程其它相關(guān)文章!

下一節(jié):.net core 使用阿里云分布式日志的配置方法

asp.net編程技術(shù)

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频