Posté par Cedric, le 27/04/2009 - Technologie
Lorsqu'on réalise un projet web d'envergure, il convient de prendre en compte les éléments annexes au développement: le référencement naturel (c'est le cas pour de plus en plus de développeur), et, chose moins commune, le déploiement et l'évolutivité de l'hébergement.
Si vous êtes sur financement, cette question pourra être rapidement éludée en passant par des prestataires à obligation de résultats, qui se chargeront pour vous de monter la meilleure architecture possible, quel qu'en soit le prix.
En revanche si vous êtes en auto-financement, les solutions techniques vous permettant de construire une architecture évolutive à moindre coût vous intéresseront. A notre sens, il convient ainsi de canaliser les goulets d'étranglement du serveur (généralement, la RAM, le processeur, et les écritures simultanées sur le disque dur, hors swap) en séparant les tâches sur des serveurs différents, ce qui permet de monter des système extensibles et légers.
Ainsi, un site avec du PHP extensif, comme une application sous symfony sera réparti ainsi:
- Un serveur avec pas mal de RAM pour servir le frontend. Sur ce serveur, une partie de la RAM doit être allouée à un accélérateur d'opcode type APC (512 Mo dédié parait pas mal). Cela permet de garder en cache une version précompilée de vos fichiers PHP, très utile quand on utilise un framework, puisqu'un framework procède à des inclusions en série de milliers de fichiers PHP, ce qui créé une brèche de rapidité automatiquement.
- Un serveur avec pas mal de RAM/proc pour la base de données. Idéalement, cette base de données ne remplit qu'un seul des deux rôles clés: soit elle lit, soit elle écrit. Si elle écrit, elle doit être couplée à une base "esclave", elle même sur un serveur à part, avec encore moins de RAM. Si vous optez pour un tel système, sachez que cela implique pas mal de changement côté applicatif, puisque vous devez signaler à chaque action persistante la base de données à utiliser. Dans la théorie, des ORM avancés comme Doctrine et son fameux système de listeners permettent de faire cela. Dans la pratique, on a beaucoup de surprises.
- Un + qui fera toute la différence: si vous avez assez de RAM, et si vos serveurs de DB sont connectés à votre serveur de front en VLAN, profitez-en pour installer Memcache sur ce serveur, ouvrir le port adéquat, et stockez-y vos sessions utilisateurs. Memcache est infiniment plus rapide qu'un stockage sur disque dur, car les couples clés/valeurs sont stockés directement dans la mémoire vive. Autre avantage, le fait d'avoir vos sessions stockées directement sur un serveur dédié à cette tâche rend votre serveur d'application encore plus indépendant, ce qui facilite, si besoin est, son extension par quelque méthode que ce soit (load balancing, failover heartbeat, round robin, etc...).
- Ensuite, nous vous recommandons de vous débarasser de la gestion des "assets" (éléments persistants uploadés par les administrateurs ou les utilisateurs, typiquement des images). En plus d'encombrer votre bande passante et de démultiplier vos lectures/écritures sur disque dur (ce qui augmente considérablement les risques de casse et pose le souci de la sauvegarde), vous rendez votre cluster de front plus difficile à mettre en place. En effet, pour que celui-ci soit efficace, il faut que chaque serveur contienne exactement la même chose. S'il existe des solutions de synchronisation comme rsync, ou mieux, unison, l'idéal est à notre sens de passer par un système de stockage tiers, comme Amazon S3 ou Mosso. Certes, l'implémentation côté applicatif sera plus complexe à gérer, mais vous vous débarrasserez des problèmes de sauvegarde, de sécurité, et surtout, vous allégerez considérablement votre/vos serveur(s) applicatif(s).
- Pour finir, quelque chose de plus classique, débarrassez vous de la gestion des emails. Cela monopolise beaucoup de ressources (les AV et autres antispam sont TRES gourmands en RAM), et cela requiert énormément de maintenance pour conserver un système efficace. Optez pour une solution payante (vous transférez les MX et ne vous occupez plus de rien), ou optez au "pire" pour Google Apps qui vous permet également de faire ce genre de délocalisation, souvent pour le bonheur de vos utilisateurs.
Voilà, en ayant ce réflexe délocalisation, vous pouvez bâtir un serveur applicatif ultra light, extensible à l'infini, sécurisé à tous les niveaux (lancez un petit cron sur les serveurs de DB pour faire un dump et l'envoyer sur S3, ca prend 10 mn et 20mn pour faire le travail inverse), et très rapide à mettre en place. Côté installation, nous vous recommandons de travailler sur des box identiques, montées par exemple avec un Ubuntu LTS vide, et bloqués sur tous les ports qu'on utilisera pas avec iptable, ce qui rendra le tout encore plus sécurisé.
En conclusion, faire un système scalable, c'est également penser serveurs, et penser serveurs impose bien souvent de développer des spécificités au sein même de la couche applicative. Dans un prochain article, nous étudierons d'autres moyens d'accélérer l'exécution de son application.
tags: bootstrapping, linux, serveurs, symfony
A lire aussi:
Commentaires
Posted by Amine on 28/04/2009
Posted by JPhilip on 30/04/2009
Posted by cedric on 04/05/2009
Posted by resume writers on 16/04/2010
Posted by evening dresses on 17/06/2010
Posted by xiaoxiao on 20/06/2010
Posted by coach outlet stores on 25/06/2010
Posted by nike air max on 07/07/2010
Posted by nike air max on 07/07/2010
Posted by lacewigs on 07/07/2010
Posted by mbt on 08/07/2010
Posted by rayallen on 13/07/2010
Posted by nike air max on 15/07/2010
Posted by nike shoes on sale on 21/07/2010
But the chi hair straightener is that with proper styling,short chi hair dryer can look fabulous! Short cheap hair straighteners is easy to maintain and is healthier pink hair straighteners.There are a variety of short layered cheap straighteners with different styling best hair straightener that can make women look younger.The most popular short layered pink mk4 is the short layered bob.There are many ghd mk4 to it and using colors and highlights can accentuate the mk4 straighteners.
Posted by GHD straighteners on 22/07/2010
Posted by NFL jerseys on 22/07/2010
They are designed to give your MBT Chapa the motion of walking on MBT Changa,a movement that requires the MBT Tataga of almost every muscle from your MBT Fora to your neck,forcing you to continually readjust your MBT Fanaka to gain its center of MBT Kaya.Take a look at people who walk at least 30 MBT Tunisha a day. Those who walk on the MBT Tembea become toned fasted than those who walk on flat,solid MBT VOI.
Posted by MBT shoes on 22/07/2010
Posted by UGG boots on 22/07/2010
Posted by wedding dresses 2010 on 22/07/2010
Posted by cosplay on 30/07/2010
Posted by fiwedding on 05/08/2010
Posted by moncler on 11/08/2010
Posted by chenjing123 on 22/08/2010
Posted by talent on 22/08/2010
Posted by designer wedding dresses on 25/08/2010
Posted by thefirstwatches on 31/08/2010
J'attends le prochain article!
Posted by Loïc on 27/04/2009