[Medverkad av Konstantin G.]{class="badge informative" title="Konstantin G."}
Varnish ESI block
ESI (Edge Side Includes) är speciella direktiv som du kan använda för att inkludera webbsidor på andra webbsidor.
Ett exempel:
<div>
<esi:include src="http://domain.com/index.php/page_cache/block/esi/blocks"/>
</div>
Avvikelse hämtar innehåll från http://domain.com/index.php/page_cache/block/esi/blocks
och ersätter taggen <esi>
med den.
Commerce och varnish ESI
Commerce-ramverket skapar en ESI-tagg när följande villkor är uppfyllda:
- Cachningsprogrammet är inställt på
Varnish Cache
- Ett XML-layoutelement
block
har lagts till med ettttl
-attribut
Exempel
cms_index_index.xml
:
<referenceContainer name="content">
<block class="Magento\Framework\View\Element\Template" template="Magento_Paypal::esi.phtml" ttl="30"/>
</referenceContainer>
I exemplet ovan lägger elementet block
till innehåll från mallen esi.phtml
på en hemsida och sedan uppdaterar det automatiskt var 30:e sekund.
Begränsningar
För närvarande stöder inte engelska ESI över HTTPS, vilket innebär att det automatiskt växlar till HTTP.
Magento\PageCache\Observer\ProcessLayoutRenderElement
:
private function _wrapEsi(
\Magento\Framework\View\Element\AbstractBlock $block,
\Magento\Framework\View\Layout $layout
) {
....
// Varnish does not support ESI over HTTPS must change to HTTP
$url = substr($url, 0, 5) === 'https' ? 'http' . substr($url, 5) : $url;
return sprintf('<esi:include src="%s" />', $url);
}
recommendation-more-help
386822bd-e32c-40a8-81c2-ed90ad1e198c