AFUP Forum PHP 2020 Baromètre Planète PHP

La parole est aux speakers : Benoit Viguier

Jusqu’au Forum PHP 2019, retrouvez nos interviews de speakers pour mieux comprendre leur parcours et le sujet qu’ils ou elles aborderont lors de leur conférence !

La conférence

Une année de PHP asynchrone en production

Oui, il est tout à fait possible de faire de la programmation asynchrone en PHP et il existe des librairies matures pour le mettre en place dans vos projets. Oui, ça peut améliorer considérablement la performance de vos applications, mais si c’était aussi simple tout le monde le ferait déjà. Cela fait plus d'an que les équipes de 6play ont franchit le pas sur certains projets et les applications asynchrones tiennent toutes leurs promesses en production, mais la mise en place a soulevé beaucoup de questions. À quels critères se fier pour rendre une application asynchrone? Comment former les équipes sur ces nouveaux paradigmes? Comment adapter les outils existants et comment gérer ce nouveau type de charge sur les serveurs? Voici notre retour d’expérience sur le PHP asynchrone, du développement à la production, en passant par la vie de tous les jours.

Katherine Johnson
25/10/2019
15:15-15:55

L’asynchrone est encore quelque chose de peu connu dans l’écosystème PHP, comment peut-on s’y former sans être perdu ?

C’est la bonne question à se poser si vous comptez utiliser la programmation asynchrone dans votre équipe. D’après mon expérience, il y a deux manières d’amorcer l’apprentissage : par la théorie, ou par la pratique. Commencer par la théorie nécessite peut-être un peu plus d’efforts, mais il est possible de consulter les ressources existantes pour d’autres langages (la programmation asynchrone existait bien avant le Web !), et une fois les bases bien assimilées il devient possible de répondre aux questions complexes que se posera votre équipe. C’est l’angle principal que j’avais adopté pour ma conférence de l’année dernière, faire comprendre comment ça marche et pourquoi les générateurs sont parfaitement adaptés à cet usage. Mais cette approche peut manquer de concret pour certain(e)s, et dans ce cas rien de tel que de mettre directement la main à la pâte ! Je conseille vraiment d’utiliser un framework qui utilise les générateurs, comme AMP, cela simplifie énormément la syntaxe des fonctions asynchrones et permet de se concentrer sur les problèmes de fond. Chez M6 nous avons même développé Tornado, un ensemble d’interfaces pour la programmation asynchrone via des générateurs, et des adaptateurs pour AMP, ReactPhp et Guzzle. Cette année je souhaite parler de la pratique, faire un retour d’expérience pragmatique sur la mise en place de ces nouveaux paradigmes, et j’espère justement pouvoir aider ceux qui se sentent perdus.

L’année dernière lorsque tu as présenté l’asynchrone en PHP, serverless n’était pas une technologique aussi répandue. Y a t-il une concurrence entre asynchrone et serverless ?

Il n’y a absolument aucune concurrence entre les deux (ce qui est un comble pour de la programmation asynchrone 😉 ).
Serverless et programmation asynchrone se comparent de la même façon que le vertical scaling (+ de serveurs) et l’horizontal scaling (+ de puissance). Dans le premier cas, le serverless ne rendra pas votre code plus rapide, mais il lui permettra de tenir la charge en le déployant autant de fois que nécessaire, sans avoir à vous soucier des détails d’infrastructure (IaaS). À l’inverse, le but de la programmation asynchrone est justement de rendre votre code plus rapide en limitant les temps d’attente inutiles, mais ça ne vous aidera pas beaucoup si vous subissez une charge soudaine sur vos services. Du coup, vous vous demandez sûrement si on peut bénéficier des deux, en faisant de la programmation asynchrone serverless : la réponse est oui. Rien ne vous empêche d’avoir une lambda qui fait plein d’appels réseaux asynchrones. Le fait que PHP s’arrête après chaque requête (dans une lambda ou pas) ne nous empêche pas de lancer une Event Loop le temps du traitement, pour optimiser l’usage du CPU, c’est l’approche que nous utilisons depuis 1 an maintenant.

Tu as évangélisé précédemment sur le SQL, sur les tableaux et maintenant sur l’asynchrone. Quelle est la prochaine brique utilisée massivement mais méconnue que tu penses creuser ?

Si seulement je le savais… 😉
Que ce soit au travail ou en dehors, je m’intéresse à beaucoup de choses liées (ou pas) à PHP, j’aime bien sortir des sentiers battus ou au contraire m’intéresser à un détail et l’étudier à fond. En ce moment je m’amuse beaucoup à faire du « PHP Graphique » grâce à l’extension PhpSdl : pouvoir afficher une fenêtre, faire bouger des images, interagir avec clavier et souris… presque faire du frontend en PHP au final ! J’aime beaucoup les réactions que ça suscite, de « On peut faire ça ? » à « Mais pourquoi tu fais ça ? ». Même si ça a peu de chance d’avoir un intérêt professionnel, ça me permet d’étudier comment fonctionne une extension, car c’est une partie de PHP que je connais assez peu et qui pourtant m’intéresse beaucoup. Après tout, ça pourrait être une idée pour un prochain talk !

Le speaker

Benoit VIGUIER
Benoit VIGUIER
Lead Développeur Backend sur 6play, chez M6 Distribution. Initialement développeur 3D pour le jeu vidéo ou la CAO, mais reconverti dans le Web depuis 6 ans. Qu'importent les technologies, pourvu qu’on ait l'ivresse.

Autres interviews

En poursuivant votre navigation sur ce site, vous acceptez l’utilisation des cookies pour améliorer votre navigation. plus d'infos

1. Qu’est-ce qu’un cookie?

Un Cookie est un petit fichier texte enregistré sur votre terminal (ordinateur, tablette, smartphone, etc.), à l’occasion de la consultation d’un service en ligne grâce à votre logiciel de navigation. Il permet à son émetteur d’identifier le terminal dans lequel il est enregistré, pendant la durée de validité ou d’enregistrement du Cookie. Lors de la consultation de notre site Internet, des informations relatives à la navigation de votre terminal sont susceptibles d'être enregistrées dans ces fichiers dits "Cookies". Ces derniers sont installés sur votre terminal, sous réserve des choix que vous auriez exprimés concernant les Cookies et que vous pouvez modifier à tout moment.

2. A quoi servent les cookies émis sur notre site ?

Seul l’émetteur d’un cookie est susceptible de lire ou de modifier les informations qui y sont contenues.
Les cookies utilisés sur notre site permettent :

3. Vos choix concernant les cookies

Vous disposez de différents moyens pour gérer les cookies. Tout paramétrage que vous pouvez entreprendre sera susceptible de modifier votre navigation sur notre site et sur Internet en général et vos conditions d'accès à certains services de notre site nécessitant l'utilisation de cookies. Vous pouvez à tout moment exprimer et modifier vos souhaits en matière de cookies, par les moyens décrits ci-dessous. L'accord sur les cookies L'enregistrement d'un cookie dans un terminal est essentiellement subordonné à la volonté de l'utilisateur du terminal, que celui-ci peut exprimer et modifier à tout moment et gratuitement à travers les choix qui lui sont offerts par son logiciel de navigation. Si vous avez accepté dans votre logiciel de navigation l'enregistrement de cookies dans votre terminal, les cookies intégrés dans les pages et contenus que vous avez consultés pourront être stockés temporairement dans un espace dédié de votre terminal. Ils y seront lisibles uniquement par leur émetteur.

Le refus des cookies Si vous refusez l'enregistrement de cookies dans votre terminal, ou si vous supprimez ceux qui y sont enregistrés, vous ne pourrez plus bénéficier d'un certain nombre de fonctionnalités qui sont néanmoins nécessaires pour naviguer dans certains espaces de notre site. Tel serait le cas si vous tentiez d'accéder à votre compte ou à votre abonnement qui nécessite de vous identifier. Tel serait également le cas lorsque nous, ou nos prestataires, ne pourrions pas reconnaître, à des fins de compatibilité technique, le type de navigateur utilisé par votre terminal, ses paramètres de langue et d'affichage ou le pays depuis lequel votre terminal semble connecté à Internet. Le cas échéant, nous déclinons toute responsabilité pour les conséquences liées au fonctionnement dégradé de nos services résultant de l'impossibilité pour nous d'enregistrer ou de consulter les cookies nécessaires à leur fonctionnement et que vous auriez refusés ou supprimés. Les choix offerts par votre logiciel de navigation Vous pouvez configurer votre logiciel de navigation de manière à ce que des cookies soient enregistrés dans votre terminal ou, au contraire, qu'ils soient rejetés, soit systématiquement, soit selon leur émetteur. Vous pouvez également configurer votre logiciel de navigation de manière à ce que l'acceptation ou le refus des cookies vous soient proposés ponctuellement, avant qu'un cookie soit susceptible d'être enregistré dans votre terminal. Pour la gestion des cookies et de vos choix, la configuration de chaque navigateur est différente. Elle est décrite dans le menu d'aide de votre navigateur, qui vous permettra de savoir de quelle manière modifier vos souhaits en matière de cookies. Selon votre navigateur, consultez le lien ci-dessous pour configurer votre navigateur et refuser les cookies :