Denna artikel är en spegelartikel om maskinöversättning, klicka här för att hoppa till originalartikeln.

Utsikt: 3487|Svar: 3

[Källa] .NET 6 testar Gzip- och Brotli-algoritmer

[Kopiera länk]
Publicerad på 2023-09-17 10:45:34 | | | |
Krav: HTTP lägger nu till en Brotli-komprimeringsalgoritm för att testa Gzip- och Brotli-algoritmer. Beroende på projektet testas endast dekompressionshastigheten i artikeln.

Brotli har12 nivåer av kompression, från 0 till 11, där 0 ger snabbast komprimeringshastighet men lägsta komprimeringsförhållande, medan 11 ger högst komprimeringsförhållande men kräver mer beräkningsresurser och tid. När vi först implementerade Brotli för 5 år sedan fastställde vi att fyrnivåkomprimering gav en balans mellan bytebesparingar och komprimeringstid utan att kompromissa med prestandan. Ju högre komprimeringsnivå, desto mindre fotavtryck, men den säljer fler CPU- och minnesresurser.

ASP.NET Brotli-algoritmen är redan inbyggd i kärnan och kräver ingen referens till tredjepartspaket. (Denna artikel kommer att referera till tredjepartspaketet: BrotliSharpLib och det inbyggda för jämförelse), konfigurationen är följande:


ASP.NET Core Brotli komprimeringsanropsflöde: ResponseCompressionServicesExtensions -> AddResponseCompression -> ResponseCompressionProvider -> BrotliCompressionProvider -> BrotliStream.



Komprimeringsnivåns uppräkningskod är följande:

Skapa ett nytt .NET 6-konsolprojekt med följande benchmarkkod:


Testresultaten är följande:



Jag testade en 503kb-fil, och efter komprimeringen var det inte mycket skillnad, allt runt 400kb, och det visade sig att Gzips dekomprimeringshastighet fortfarande var snabbare än Brotlis, vilket borde vara densammafilstorlek, . NET-version, komprimeringsnivå, filinnehåll, etcKort sagt, det är bäst att välja den scen som passar dig.

Om du stöter på ett fel som detta:

Miljö
  Sammanfattning - > Upptäckt felutgångskod från en av benchmarkarna. Det kan orsakas av följande antivirusprogram:
        - 360 SafeGuard (C:\Program Files (x86)\360\360Safe\safemon\360tray.exe)
        - Windows Defender (windowsdefender://)
Använd InProcessEmitToolchain eller InProcessNoEmitToolchain för att undvika ny processskapande.
lösning

eller
(Slut)





Föregående:[Vänd]. NET använder Brotli för att komprimera och dekomprimera data
Nästa:EF6 Required tillåter tomma strängar men inte nulliteter
 Hyresvärd| Publicerad på 2023-09-17 10:46:46 |

asp.net kärna 3.1 möjliggör webbplatsens Brotli-komprimeringsalgoritm
https://www.itsvse.com/thread-9532-1-1.html

.net/c# GZipStream datakomprimering
https://www.itsvse.com/thread-4240-1-1.html




 Hyresvärd| Publicerad på 2023-09-17 10:48:01 |
[Vänd]. NET använder Brotli för att komprimera och dekomprimera data
https://www.itsvse.com/thread-10662-1-1.html
 Hyresvärd| Publicerad på 2025-01-07 10:18:37 |
【zip】. NET/C# använder inbyggd System.IO.Compression för att komprimera och dekomprimera
https://www.itsvse.com/thread-10912-1-1.html
Friskrivning:
All programvara, programmeringsmaterial eller artiklar som publiceras av Code Farmer Network är endast för lärande- och forskningsändamål; Ovanstående innehåll får inte användas för kommersiella eller olagliga ändamål, annars kommer användarna att bära alla konsekvenser. Informationen på denna sida kommer från internet, och upphovsrättstvister har inget med denna sida att göra. Du måste helt radera ovanstående innehåll från din dator inom 24 timmar efter nedladdning. Om du gillar programmet, vänligen stöd äkta programvara, köp registrering och få bättre äkta tjänster. Om det finns något intrång, vänligen kontakta oss via e-post.

Mail To:help@itsvse.com