NGINX Open Source[2] ou NGINX (prononcé [ˌɛndʒɪnˈɛks] et également orthographié Nginx ou nginx) est un logiciel libre de serveur Web (ou HTTP) ainsi qu'un proxy inverse écrit par Igor Sysoev, dont le développement a débuté en 2002 pour les besoins d'un site russe à très fort trafic (Rambler). La documentation est disponible dans plusieurs langues. C'est depuis , le serveur web le plus utilisé au monde d'après Netcraft[3], ou le deuxième serveur le plus utilisé d'après W3techs[4].
Créateur | NGINX, Inc. (en) |
---|---|
Développé par | Maxim Dounin (d) et Igor Sysoev |
Première version | 4 octobre 2004, il y a 20 ans |
Dernière version | 1.27.2 ()[1] |
Dépôt | github.com/nginx/nginx |
Écrit en | C |
Système d'exploitation | Type Unix et Microsoft Windows |
Formats lus | PEM encoded certificate (d), PEM encoded RSA private key (d), Nginx sites-available (d) et Nginx configuration file (d) |
Type |
Serveur web Mandataire |
Politique de distribution | logiciel libre |
Licence | BSD 2-clauses (en) |
Documentation | nginx.org/en/docs et nginx.org/ru/docs |
Site web | nginx.org |
NGINX Inc est racheté par F5 Networks le , pour 670 millions de dollars.
Un premier fork du nom d'Angie est créé par une partie des principaux développeurs de nginx, dont Igor Sysoev, en novembre 2022[5],[6].
Le , Maxim Dounin, le dernier des deux principaux développeurs de Nginx à travailler pour F5 Network, annonce qu'à la suite à des différends sur la gestion de la sécurité avec la société, il décide de forker nginx en Freenginx au sein de l'organisation Freenginx[6].
Ses sources sont disponibles sous une licence de type BSD.
Particularités
Serveur asynchrone
NGINX est un système asynchrone par opposition aux serveurs synchrones où chaque requête est traitée par un processus dédié. Au lieu d'exploiter une architecture parallèle et un multiplexage temporel des tâches par le système d'exploitation, NGINX utilise les changements d'état pour gérer plusieurs connexions en même temps ; le traitement de chaque requête est découpé en de nombreuses mini-tâches et permet ainsi de réaliser un multiplexage efficace entre les connexions. Afin de tirer parti des ordinateurs multiprocesseurs, plusieurs processus peuvent être démarrés. Ce choix d'architecture entraine des performances très élevées, ainsi qu'une charge et une consommation de mémoire très inférieures à celles des serveurs HTTP classiques comme Apache.
Modularité
NGINX est très modulaire : un noyau minimal et de nombreux modules, venant compléter les fonctions de base. Chaque module peut agir comme un filtre sur le contenu en entrée, en sortie ou intermédiaire (proxy) par le biais de nombreuses fonctions de rappel (callbacks). Ainsi, à titre d'exemple, un contenu dynamique peut être compressé à la volée par le module « gzip » avant envoi.
Ces modules sont liés au serveur lors de la compilation. NGINX ne supporte pas les bibliothèques dynamiques partagées. Tengine, la fourche (fork) de NGINX de Taobao a ajouté cette fonctionnalité, qui n'a pas été reportée sur NGINX[7].
Optimisations
Le noyau s'appuie sur des structures de données minimales, mais optimales, visant à réduire le nombre d'appels système, en particulier pour tout ce qui a trait à l'allocation de mémoire. Différents mécanismes de signalisation peuvent être utilisés afin d'exploiter au mieux le système d'exploitation (par exemple : epoll sous Linux et kqueue sous BSD). L'architecture asynchrone soulage l'ordonnanceur du système d'exploitation et favorise l'utilisation des caches ou du/des processeur(s).
Divers
Un processus maître contrôle le ou les processus serveurs. Ceci permet des changements de configuration ou la mise à jour du fichier exécutable du serveur sans interruption du service HTTP.
Plates-formes prises en charge
NGINX fonctionne sous les systèmes d'exploitation GNU/Linux, BSD, Mac OS X et Solaris ; à partir de la version avancée 0.7.52, NGINX est également disponible pour Microsoft Windows.
Utilisations
Outre le fait d'être un serveur HTTP, NGINX peut être configuré pour être un serveur mandataire inverse (en anglais : reverse proxy) Web et un serveur proxy de messagerie électronique (IMAP / POP3). L'utilisation la plus fréquente de NGINX est de le configurer comme un serveur Web classique pour servir des fichiers statiques et comme un proxy pour les requêtes dynamiques typiquement acheminées en utilisant une interface FastCGI vers un ou des serveurs applicatifs avec un mécanisme de répartition de charge.
NGINX est également capable de diffuser, selon le même principe que lighttpd avec mod_flv_streaming, du contenu vidéo en mode continu (streaming) vers un lecteur Flash sans avoir à recourir à Flash Media Server. Pour cela, il comporte un module optionnel http_glv_module de streaming de fichier vidéo flv et plusieurs modules de streaming qui peuvent diffuser une vidéo encodée en H.264. Il permet également de diffuser du mp4 grâce à son module optionnel http_mp4_module.
Il est aussi très utilisé en production pour servir des applications en Ruby on Rails grâce au module Phusion Passenger. La plupart des sites en Ruby on Rails à fort trafic utilisent NGINX (par exemple basecamp ou encore LinuxFr.org[8]).
Popularité
NGINX était peu connu, excepté en Russie, avant qu'Aleksandar Lazic ne commence la traduction anglaise en 2006.
- En , Google le considérait comme le 3e serveur (4 % d'utilisation) parmi les serveurs web les plus fréquentés, après Apache (66 %) et IIS de Microsoft (23 %)[9].
- En , selon Netcraft, avec plus de 3,3 millions de domaines, NGINX apparaît pour la première fois au rang de quatrième serveur HTTP[10] le plus utilisé au monde (juste devant lighttpd).
- En , cette tendance est confirmée : Apache 66,65 %, IIS 18,68 % et NGINX 3,06 %[11] (alors que lighttpd n'obtient plus que 0,99 %, et est aussi dépassé par Google Web Server à 1,56 %).
- En , NGINX est d'après Netcraft le troisième serveur le plus utilisé sur les sites web mondiaux avec 6,04 % de part de marché, derrière les 22,70 % d'IIS et les 59,36 % d'Apache[12].
- En , ces chiffres restent globalement stables : 64,66 % pour Apache, 16,82 % pour IIS, 6,55 % pour NGINX, 4,61 % pour Google Web Server[13].
- Runa Capital a investi dans le développement de NGINX en 2011[14].
- En , NGINX dépasse légèrement IIS, avec 12,18 % contre 12,14 %[15].
- En , NGINX continue sa progression, avec 12,91 % des sites actifs, alors que Apache passe à 54,37 %, IIS reste stable à 12,13 % et Google Web Server passe à 8,12 %[16].
- En , concernant les sites actifs, NGINX est utilisé sur 13,81 %, Apache 50,98 %, IIS 10,83 % et Google s'est effondré à 2,42 %. Sur le million de sites les plus visités, l'écart s'est creusé avec IIS. NGINX obtient 21,64 % des sites derrière Apache HTTPD à 48,83 %, tandis qu'IIS n'obtient que 12,13 % des sites sur ce critère[17].
- En , NGINX est utilisé sur 17 % des sites actifs, contre 49 % à Apache, 10 % à IIS, et un peu moins de 8 % à Google. En ce qui concerne le million de sites les plus visités, il totalise plus de 25 % des sites et est en augmentation constante, derrière Apache à 45 % et devant IIS à 11 %[18].
- En , selon Netcraft, NGINX est utilisé sur 22 % des sites actifs, contre 30 % pour Apache, 8 % pour Google. En ce qui concerne le million de sites les plus visités, il totalise plus de 26 % des sites, derrière Apache à 33 % et devant IIS à 9 %[19].
- En , il devient le serveur web le plus utilisé, à la fois en nombre de sites et en nombre d'ordinateurs[3].
Notes et références
Voir aussi
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.