Ušetřete až 80 % datového přenosu
Podporuje-li váš webový server skriptování v jazyce PHP, můžete omezit datový tok mezi serverem a klientským počítačem zhruba o 80 procent a tím i případné poplatky za přenášená data. O omezení toku se postará output buffering. Podívejme se na jeho výhody.
Output buffering můžete zapnout kdykoli v průběhu skriptu. Veškerý výstup PHP skriptu (jakýkoli HTML kód nebo jakýkoli jiný výstup pomocí funkcí echo či print) pak nebude okamžitě odesílán klientskému počítači, ale bude uchováván v paměti serveru (bufferu). Pokud tento buffer ve skriptu načteme do proměnné, můžeme s ním nakládat jako s kteroukoli jinou proměnnou, kterou můžeme například uložit na disk. Output buffering je podporován každou verzí PHP4. PHP3 ho bohužel nepodporuje.
Pokud ve skriptu zapnete output buffering, nastává několik vyjímek z pravidel PHP. Konkrétně se jedná o posílání cookies a posílání hlaviček. Ty musí být skriptem za normálních okolností odeslány ještě dříve, než PHP vyprodukuje jakýkoli datový výstup (tento výstup může být i prázdný řádek nebo mezera – zdroj častých chyb), jinak dojde k varování (nelze poslat hlavičku, výstup skriptu byl již zahájen). Při zapnutém bufferingu však toto pravidlo neplatí. Veškerý výstup skriptu totiž končí v bufferu a PHP nepošle klientovi nic, dokud skript neskončí, nebo mu to nepřikážete. Díky tomu lze docela dobře ošetřit například chybu při práci s databází stávající výstup skriptu se jednoduše zruší a na výstup pošlete celou stránku s upozorněním na chybu při práci s databází.
Jak jsem uvedl již v názvu článku, je možné použitím této metody ušetřit až 80 % datového toku. Jak toho docílit? Nejdříve bude nutné zapnout output buffering. Jsou dvě možnosti. Jedna spočívá v nastavení php.ini. Zapnutí provede direktiva:
|
Pokud chcete velikost výstupního bufferu omezit (omezí se paměťové nároky PHP), můžete v direktivě místo parametru On uvést velikost bufferu v bajtech. Toto použití však příliš nedoporučuji, protože by se mohlo stát, že generovaný výstup skriptu by mohl být větší než maximální velikost bufferu. To by mohlo vést k neočekávanému chování PHP skriptů nebo nežádoucím chybám.
Druhou možností je zapnout buffering přímo ve skriptu. Toho docílíte pomocí funkce:
|
Doporučuji použít tuto funkci hned na začátku skriptu (je-li to možné). Skript pak může pokračovat normálním způsobem. Při ukončení PHP skriptu bude buffer odeslán klientovi. Odeslání bufferu klientovi můžete vynutit. K tomu slouží funkce, která zastaví buffering a pošle data klientovi:
|
Pokud bude nevhodné posílat bufferovaná data klientovi, můžete bufferování ukončit a stávající buffer vymazat pomocí funkce
|
GZIPovaný přenos
GZIPovaný přenos posílá data (HTML kód, JS, CSS, obrázky nebo i binární soubory) prohlížeči gzipovaná. Hlavička na to prohlížeč upozorní a po přijetí celého přenášeného obsahu prohlížeč data rozbalí a zcela normálním způsobem zpracuje. Výhoda takového přenosu je jasná: nekomprimovaná data jsou náročnější na datový přenos. GZIPová metoda dokáže ušetřit až 80 procent tohoto přenosu, zaleží však na obsahu gzipovaných dat. Rozhodně se touto metodou nevyplatí posílat obrázky. Zmíněné komprese lze dosáhnout u textových souborů, což urychlí načítání např. informačních serverů, jejichž stránky jsou datově náročné.
Všechny moderní internetové prohlížeče podporují posílání gzipovaného obsahu. Zda to podporuje i ten váš, zjistíte v proměnné ACCEPT_ENCODING (například pomocí phpinfa). Pokud tam bude mj. uvedeno gzip, tak prohlížeč tuto metodu zasílaných dat podporuje. Pokud tam gzip uvedeno není, nebude prohlížeč umět gzipovaná data přijmout, respektive zpracovat.
Pokud máte PHP ve verzi 4.0.4 a vyšší, a je zkompilováno s podporou knihovny zlib, můžeme bufferovaná data posílat na klienta gzipované. Toho docílíme drobnou změnou funkce ob_start() a to tak, že použijeme nepovinný atribut funkce, kterým definujeme funkci, která se o bufferovaná data postará před odesláním prohlížeči. Zápis funkce bude vypadat následovně:
|
Funkce ob_gzhandler
se tedy postará o gzipovaní výstupních dat. Automaticky pozná, zda prohlížeč podporuje zpracování gzipovaných dat, proto se nemusíte zabývat ošetřením skriptu proti posílání gzipovaných dat klientovi, který gzip nepodporuje. Také nemusíte buffer načíst do proměnné a ručně ho gzipovat.
Při použití ob_gzhandler
nejste ale schopni ovlivnit úroveň komprese, což je docela škoda. Pak by se tak dalo předejít případnému přetěžování serveru snížením úrovně komprese.
Výsledný skript posílající gzipovaná data bude vypadat následovně:
|
S PHP nižší než 4.0.4
Pokud máte na serveru PHP 4, ale nižší verzi než 4.0.4, můžete posílat gzipovaná data pomocí output bufferungu. Bohužel bude nutné použít pracnějšího postupu. Nejdříve bude potřeba zjistit, zda prohlížeč podporuje zpracování gzipovaných dat. Pokud ano, ahájít buffering a definujet funkci, která zpracuje výstupní data. Pokud ne, nic se nestane a skript bude pokračovat zcela normálně dále. Možností, jak provést gzipování dat v proměnné je několik (uvádím alternativu použitou i v oficiálním manuálu):
|
Vedle PHP lze nechat gzipovat i samotný apache. Výhodou nastavení apache je možnost gzipovat i jiná data než ta, která vyprodukuje PHP – můžete gzipovat statické html stránky, nebo i perlovské a CGI skripty. Pro příklad uvádím jednoduchou konfiguraci apache:
|
Ukládání na disk
Další praktické využití output bufferingu je v podobě ukládání bufferu na disk. Jelikož buffer v podstatě obsahuje celou HTML stránku, můžete ho uložit na disk jako html soubor a následně jej volat místo PHP skriptu, případně jej například místo složitého a náročného generování z databáze vložit do skriptu. V krátkosti uvedu jednoduchý příklad:
|
Účel tohoto postupu je jasný. Opakované generování stránky z databáze zatíží server daleko více, než volání statické HTML stránky, případně její začlenění do PHP skriptu. V případě aktualizace databáze je však nutné tyto soubory z disku smazat, jinak by se změna samozřejmě neprojevila.
Závěrem předvedu spojení obou možností – vygenerování souboru na disk a následné poslání gzipovaných dat. Vycházet budu z mírně upraveného předchozího příkladu
|
Starší komentáře ke článku
Pokud máte zájem o starší komentáře k tomuto článku, naleznete je zde.
Mohlo by vás také zajímat
-
Jak se chránit před podvody na internetu – část 2
14. října 2024 -
Jak vybrat doménu: Co je dobré vědět?
2. září 2024 -
Gaming na HDR monitoru: Stojí to za to?
12. srpna 2024 -
Nepodceňte UX na vašem webu: Proč na něm záleží?
10. dubna 2024
Nejnovější
-
Apple jde naproti práci s HDR monitory!
17. ledna 2025 -
Jak využít AI potenciál svého Macu?
9. ledna 2025 -
NIS2: Verifikace údajů vlastníků domén
6. ledna 2025 -
Dostali jste k vánocům PC? Využijte jeho AI potenciál!
3. ledna 2025