Facebook has a “Lazy Loading” system they call “BigPipe” that helps the pages load fast. Facebook breaks each page down into sections they call “Pagelets”, and using Javascript only load the most important Pagelets first then load the less important ones shortly afterward.
And pipeline them through several execution stages inside web servers and browsers, as the modern microprocessor do to serve the various request in an order to increase the productivity.
Big Pipe is totally implemented in PHP and javascript.
By loading and rendering the main page structure first with minimal info on it, the page appears to load quicker than having to wait for a complete page to download and then render.
To exploit the parallelism between web server and browser, BigPipe first breaks web pages into multiple chunks called pagelets. Just as a pipelining microprocessor divides an instruction’s life cycle into multiple stages (such as “instruction fetch”, “instruction decode”, “execution”, “register write back” etc.), BigPipe breaks the page generation process into several stages:
- Request parsing: web server parses and sanity checks the HTTP request.
- Data fetching: web server fetches data from storage tier.
- Markup generation: web server generates HTML markup for the response.
- Network transport: the response is transferred from web server to browser.
- CSS downloading: browser downloads CSS required by the page.
- DOM tree construction and CSS styling: browser constructs DOM tree of the document and then applies CSS rules on it.
- JavaScript downloading: browser downloads JavaScript resources referenced by the page.
- The JavaScript execution: browser executes JavaScript code of the page.
The first three stage are executed by the web server and last four step by the browser. But BigPipe enables several pagelets simultaneously.
As Facebook Homepage, when you put url-www.facebook.com in the browser. Then what's happen is homepage start to render pagelets by pagelets. Like-"“composer pagelet", "navigation pagelet", "news feed pagelet", "request box pagelet" and then the news feed is also divided into pagelets and after scrolling it get executed.
After flushing, the first response to the client, web server continues to generate pagelets one by one. As soon as a pagelet is generated, its response is flushed to the client immediately in a JSON-encoded object that includes all the CSS, JavaScript resources needed for the pagelet, and its HTML content, as well as some meta data. For example:
<script type="text/javascript">
big_pipe.onPageletArrive({id: “pagelet_composer”, content=<HTML>, css=[..], js=[..], …})
</script>
Source- Facebook BigPipe
I often use Facebook, sometimes it's very slow,You gave me some practical method, useful, thanks for sharing.
ReplyDeleteThanks for reading !!
DeletePlease visit again.