27 avril 2023

Vernis ou NGINX FastCGI Cache comme système de cache ?

Découvrons comment l'utilisation des deux dans la même pile logicielle peut combler les lacunes des deux dans la version gratuite.

Il y a eu une guerre religieuse en cours depuis un certain temps pour savoir quel est le meilleur cache pour les serveurs Web. Il y a les éternels puristes qui recommandent une cache comme Varnish Cache et les novices qui la recommandent Cache NGINX FastCGI dont nous parlons dans cet article, en tant que méthode plus rapide, plus simple et moins complexe pour fournir la fonctionnalité de mise en cache HTTP (et bien sûr HTTPS).

Il y a ceux comme nous qui soutiennent que Varnish a plus de fonctionnalités et permet, grâce à son langage de configuration Vansh (VLC ed) de générer des configurations et des configurations de mise en cache vraiment complexes et avancées, et il y a ceux qui soutiennent que les mêmes choses peuvent être faites avec quelques lignes de configuration supplémentaires directement dans NGINX, sans ajouter de couches de cache comme Varnish.

Vernis VCL Exemple

Normalement dans ces comparaisons, chacun apporte de l'eau à son moulin, à ce qu'il utilise habituellement, à ce qu'il sait utiliser le plus ou trouve le plus confortable. Par exemple, vous voulez mettre la flexibilité de Varnish Cache et la compatibilité avec WordPress grâce à des plugins standards du marché tels que W3 Total Cache, Proxy Cache Purge, WP Fastest Cache ou le très commercialisé WP Rocket ?

Vernis WP Rocket
Vernis WP Rocket

 

Vernis de cache le plus rapide WP
Option de vernis de cache le plus rapide WP

Objectivement, lorsque nous parlons de WordPress et de ses performances, nous sommes les premiers à souligner à quel point il est important pour nous d'avoir une pile basée sur Varnish en tant que cache de page complète. Cependant, a-t-on vraiment raison d'affirmer que le cache NGINX est un "jouet" pour les administrateurs système inexpérimentés ? Et quand certains de nos confrères nous reprochent d'utiliser un cache comme Varnish qui pourrait en fait être sauvegardé grâce au cache NGINX, nous reprochent d'alourdir une pile logicielle qui pourrait être plus allégée, ont-ils vraiment raison ?

Bref, entre Varnish et NGINX quel cache est le meilleur ?

Pour répondre à cette question, il faut nécessairement prendre du recul et s'éloigner de ses convictions, rechercher une approche ouverte vis-à-vis de ce que l'on n'a pas utilisé ou mal utilisé jusqu'à présent et commencer à comprendre les modèles commerciaux de Varnish et NGINX et comment, à partir d'une compréhension de leurs limites respectives, ils peuvent s'inclure et non s'exclure.

Modèles commerciaux de Varnish et NGINX

Varnish et NGINX sont deux serveurs proxy populaires utilisés pour améliorer les performances des applications Web et assurer une meilleure expérience utilisateur. Ce qui rend ces logiciels encore plus intéressants, c'est qu'ils sont tous deux développés selon la philosophie open source, ce qui signifie qu'ils sont librement disponibles pour que quiconque puisse les utiliser et les modifier.

Cependant, il existe également une version commerciale des deux logiciels : NGINX Plus et Varnish Enterprise. Ces versions sont livrées avec des fonctionnalités avancées et des fonctionnalités supplémentaires, qui ne sont pas disponibles dans les versions gratuites. Ces fonctionnalités incluent le support officiel de l'entreprise, les assurances qualité des logiciels et même des outils d'analyse des performances.

Ce qui différencie le plus ces versions commerciales des versions gratuites, c'est leur prix. Les deux versions commerciales ont des coûts de licence de plusieurs dizaines de milliers de dollars par an. Cela signifie que ces licences sont principalement destinées aux entreprises qui ont besoin de fonctionnalités avancées et sont prêtes à payer pour une assistance et des garanties supplémentaires.

Surmontez les limitations respectives en utilisant à la fois NGINX et Varnish

Sachant que NGINX et Varnish ont des limitations dans leurs versions gratuites, nous pouvons toujours les surmonter en utilisant les deux serveurs proxy en combinaison.

Par exemple, NGINX peut être utilisé comme service de microcaching. De cette manière, NGINX est utilisé comme premier niveau de mise en cache, où les données fréquemment demandées par les utilisateurs sont stockées. Lorsqu'une requête arrive sur le serveur, NGINX vérifie son cache pour voir si la réponse s'y trouve déjà. Si c'est le cas, NGINX renvoie immédiatement la réponse au client sans avoir à passer à l'étape suivante du traitement.

Microcache NGINX

En combinaison avec Varnish, NGINX peut être utilisé comme frontal pour le serveur de mise en cache Varnish. Dans ce scénario, les demandes des clients sont initialement traitées par NGINX. Si les données demandées ne se trouvent pas dans le cache de NGINX, la demande est transmise au serveur Varnish, qui dispose d'un cache plus grand et plus robuste. Varnish a la capacité de stocker de grandes quantités de données dans la RAM, ce qui le rend beaucoup plus rapide que les caches classiques comme Memcached et Redis.

Lorsqu'un client demande des informations, NGINX les recherche dans son cache. Si la réponse est là, NGINX l'envoie directement au client. Sinon, la demande est transmise à Varnish, qui à son tour vérifie son cache pour voir si la réponse s'y trouve. Si la réponse est présente dans le cache Varnish, elle est renvoyée au client via NGINX.

Cette combinaison de mise en cache peut améliorer considérablement les performances des applications Web. De plus, il est possible de personnaliser le comportement du cache en utilisant les options de configuration offertes par les deux serveurs proxy et avec quelques précautions pour s'assurer que le serveur web ne renvoie jamais un MISS en réponse, garantissant ainsi d'excellents temps de réponse inférieurs à 30ms.

 

 

 

Vous avez des doutes ? Vous ne savez pas par où commencer ? Contactez-nous !

Nous avons toutes les réponses à vos questions pour vous aider à faire le bon choix.

Discute avec nous

Discutez directement avec notre support avant-vente.

0256569681

Contactez-nous par téléphone pendant les heures de bureau 9h30 - 19h30

Contactez-nous en ligne

Ouvrez une demande directement dans l'espace contact.

INFORMATIONS

Managed Server Srl est un acteur italien leader dans la fourniture de solutions système GNU/Linux avancées orientées vers la haute performance. Avec un modèle d'abonnement peu coûteux et prévisible, nous garantissons que nos clients ont accès à des technologies avancées en matière d'hébergement, de serveurs dédiés et de services cloud. En plus de cela, nous proposons des conseils système sur les systèmes Linux et une maintenance spécialisée en SGBD, sécurité informatique, Cloud et bien plus encore. Nous nous distinguons par notre expertise dans l'hébergement de CMS Open Source de premier plan tels que WordPress, WooCommerce, Drupal, Prestashop, Joomla, OpenCart et Magento, soutenus par un service d'assistance et de conseil de haut niveau adapté aux administrations publiques, aux PME et à toutes tailles.

Red Hat, Inc. détient les droits de Red Hat®, RHEL®, RedHat Linux® et CentOS® ; AlmaLinux™ est une marque commerciale d'AlmaLinux OS Foundation ; Rocky Linux® est une marque déposée de la Rocky Linux Foundation ; SUSE® est une marque déposée de SUSE LLC ; Canonical Ltd. détient les droits sur Ubuntu® ; Software in the Public Interest, Inc. détient les droits sur Debian® ; Linus Torvalds détient les droits sur Linux® ; FreeBSD® est une marque déposée de la FreeBSD Foundation ; NetBSD® est une marque déposée de la Fondation NetBSD ; OpenBSD® est une marque déposée de Theo de Raadt. Oracle Corporation détient les droits sur Oracle®, MySQL® et MyRocks® ; Percona® est une marque déposée de Percona LLC ; MariaDB® est une marque déposée de MariaDB Corporation Ab ; REDIS® est une marque déposée de Redis Labs Ltd. F5 Networks, Inc. détient les droits sur NGINX® et NGINX Plus® ; Varnish® est une marque déposée de Varnish Software AB. Adobe Inc. détient les droits sur Magento® ; PrestaShop® est une marque déposée de PrestaShop SA ; OpenCart® est une marque déposée d'OpenCart Limited. Automattic Inc. détient les droits sur WordPress®, WooCommerce® et JetPack® ; Open Source Matters, Inc. détient les droits sur Joomla® ; Dries Buytaert détient les droits sur Drupal®. Amazon Web Services, Inc. détient les droits sur AWS® ; Google LLC détient les droits sur Google Cloud™ et Chrome™ ; Facebook, Inc. détient les droits sur Facebook® ; Microsoft Corporation détient les droits sur Microsoft®, Azure® et Internet Explorer® ; La Fondation Mozilla détient les droits sur Firefox®. Apache® est une marque déposée de The Apache Software Foundation ; PHP® est une marque déposée du groupe PHP. CloudFlare® est une marque déposée de Cloudflare, Inc. ; NETSCOUT® est une marque déposée de NETSCOUT Systems Inc. ; ElasticSearch®, LogStash® et Kibana® sont des marques déposées d'Elastic NV. Ce site n'est affilié, sponsorisé ou autrement associé à aucune des entités mentionnées ci-dessus et ne représente aucune de ces entités de quelque manière que ce soit. Tous les droits sur les marques et noms de produits mentionnés sont la propriété de leurs titulaires respectifs des droits d'auteur. Toutes les autres marques mentionnées appartiennent à leurs titulaires. MANAGED SERVER® est une marque déposée au niveau européen par MANAGED SERVER SRL Via Enzo Ferrari, 9 62012 Civitanova Marche (MC) Italie.

JUSTE UN MOMENT !

Souhaitez-vous voir comment votre WooCommerce fonctionne sur nos systèmes sans avoir à migrer quoi que ce soit ? 

Entrez l'adresse de votre site WooCommerce et vous obtiendrez une démonstration navigable, sans avoir à faire absolument quoi que ce soit et entièrement gratuite.

Non merci, mes clients préfèrent le site lent.
Retour en haut de page