Maison développement back-end tutoriel php PHP实现BigPipe分chunked输出_PHP教程

PHP实现BigPipe分chunked输出_PHP教程

Jul 13, 2016 pm 05:48 PM
php yahoo 内容 indiquer exister 实现 实践 建议 Paquet 最佳 de système 输出 statique

在Yahoo系的最佳实践里,建议把静态的内容尽早的输出,在head之后就调用flush,让浏览器可以尽早去加载静态资源,包括脚本、样式、图片(javascipt,css,image一般是外链的形式)等等,后台如果有多个数据源或者api需要调用,尽可能做到完成一个输出一个,通过js在前端拼装页面,进而达到优化用户体验的效果,用户等待的时间,是木桶最短的那快木板。
下面是引用:
Flush the Buffer Early
tag: server
When users request a page, it can take anywhere from 200 to 500ms for the backend server to stitch together the HTML page. During this time, the browser is idle as it waits for the data to arrive. In PHP you have the function flush(). It allows you to send your partially ready HTML response to the browser so that the browser can start fetching components while your backend is busy with the rest of the HTML page. The benefit is mainly seen on busy backends or light frontends.
A good place to consider flushing is right after the HEAD because the HTML for the head is usually easier to produce and it allows you to include any CSS and JavaScript files for the browser to start fetching in parallel while the backend is still processing.
Example:
 
      ...
   
   
   


      ...
Facebook提出的BigPipe技术,将这种思想有了更具体的实现,大体思路是,分解网页成叫做Pagelets的小块,然后通过Web服务器和浏览器建立管道并管理他们在不同阶段的运行。
在php下做个小测试,
 
';ob_flush();flush();sleep(2);echo "b";?>
结果可以看到在ie下(7,8),不管输出内容的大小,都可以看到效果,“b“在2秒后输出,在firefox和chrome,两段文本都在2秒后展现,说明浏览器做了缓存,经过实验,缓存的大小为1024,刚好1k,也是浏览器做的优化。通过返回头可以看出,在分段输出的时候,返回包没有经过gzip。
 
通过wireshark可以看到后台输出确实是一个个chunked过来的,看来是浏览器做了工作,猜测:缓存大小应该是1024B或者MTU大小(1400B多点,看网络情况),首段输出增大到1024的时,chrome和firefox都开始正常表演了,页面里的js、css和图片在第一段下载完已经开始加载。
 
应该思考的问题:
1、传输效率,尽量利用一次传输传送尽量多的东西,根据MTU大小调整;
2、同步加载,第一块送过来的东西,尽量可以同步加载,需要注意不同浏览器可以同步加载域名的数量,需要考虑javascript对加载的block,对于不用立刻执行的内容,可以通过加defer或者干脆注释掉,等页面完成在eval进来;
3、适用范围,任何一个技术都有自己适用的场景,对于后台需要访问多个api的应用会更适合一些,像社交类的网站,搜索之类的本来就在100ms左右就展现完毕,纯玩儿技术就没意义了,chunked也不是分的越多越好,适当的,类似的最好合并起来;
4、ob_flush和flush最好结对使用,某些情况下,当用flush是没有效果的。
 
参考:
 
http://www.BkJia.com/kf/201202/118114.html
 
http://developer.yahoo.com/performance/rules.html#flush
 
http://www.BkJia.com/kf/201202/118116.html
 
http://www.BkJia.com/kf/201202/118117.html
 
http://baike.baidu.com/view/4601904.htm
 
http://www.BkJia.com/kf/201202/118118.html

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478421.htmlTechArticle在Yahoo系的最佳实践里,建议把静态的内容尽早的输出,在head之后就调用flush,让浏览器可以尽早去加载静态资源,包括脚本、样式、图片(...
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Configuration du projet CakePHP Configuration du projet CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous comprendrons les variables d'environnement, la configuration générale, la configuration de la base de données et la configuration de la messagerie dans CakePHP.

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

CakePHP travaillant avec la base de données CakePHP travaillant avec la base de données Sep 10, 2024 pm 05:25 PM

Travailler avec la base de données dans CakePHP est très simple. Nous comprendrons les opérations CRUD (Créer, Lire, Mettre à jour, Supprimer) dans ce chapitre.

Date et heure de CakePHP Date et heure de CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Routage CakePHP Routage CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous allons apprendre les sujets suivants liés au routage ?

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

CakePHP créant des validateurs CakePHP créant des validateurs Sep 10, 2024 pm 05:26 PM

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

See all articles