Apache Tomcat

Un article de Wikipédia, l'encyclopédie libre.
Apache Tomcat
Description de l'image Apache Tomcat logo.svg.
Description de cette image, également commentée ci-après
Page d'accueil de Tomcat 8.0.8
Informations
Développé par Apache Software FoundationVoir et modifier les données sur Wikidata
Première version [1] et [2]Voir et modifier les données sur Wikidata
Dernière version 10.1.20 ()[3]Voir et modifier les données sur Wikidata
Version avancée 11.0.0-M18 ()[4]Voir et modifier les données sur Wikidata
Dépôt https://github.com/apache/tomcat
Écrit en JavaVoir et modifier les données sur Wikidata
Système d'exploitation GNU/Linux, Microsoft Windows, BSD et macOSVoir et modifier les données sur Wikidata
Environnement Machine virtuelle JavaVoir et modifier les données sur Wikidata
Type Serveur d'applicationsVoir et modifier les données sur Wikidata
Licence Licence Apache version 2.0Voir et modifier les données sur Wikidata
Site web tomcat.apache.orgVoir et modifier les données sur Wikidata

Apache Tomcat ou simplement Tomcat est un serveur d'applications, plus précisément un conteneur web libre de servlets et JSP. Issu du projet Jakarta, c'est un des nombreux projets de l’Apache Software Foundation. Il implémente les spécifications des servlets et des JSP du Java Community Process[5], est paramétrable par des fichiers XML et des propriétés, et inclut des outils pour la configuration et la gestion. Il comporte également un serveur HTTP.

Environnement[modifier | modifier le code]

Tomcat est un serveur HTTP à part entière[6]. De plus, il gère les servlets et les JSP (par un compilateur Jasper compilant les pages JSP pour en faire des servlets). Tomcat a été écrit en langage Java. Il peut donc s'exécuter via la machine virtuelle Java sur n'importe quel système d'exploitation la supportant.

Catalina est le conteneur de servlets utilisé par Tomcat. Il est conforme aux spécifications servlet de Oracle Corporation et les JavaServer Pages (JSP). Coyote est le connecteur HTTP de Tomcat, compatible avec le protocole HTTP 1.1 pour le serveur web ou conteneur d'application. Jasper est le moteur JSP d'Apache Tomcat. Tomcat 9.x utilise Jasper 2, qui est une implémentation de la spécification JavaServer Pages 2.3 de Oracle. Jasper parse les fichiers JSP afin de les compiler en code Java en tant que servlets (gérés par Catalina). Pendant son exécution, Jasper est capable de détecter et recompiler automatiquement les fichiers JSP modifiés.

État de développement[modifier | modifier le code]

Architecture de Tomcat
Concepts architecturaux de Tomcat.

Les membres de la fondation Apache et des volontaires indépendants développent et maintiennent Tomcat. Les utilisateurs ont accès au code source et aux binaires sous la Apache Software License. La première version de Tomcat était la 3.0. En 2005, la version 5.x est sortie, implémentant les servlets 2.4 et les JSP 2.0. Depuis sa version 4.x, Tomcat utilise le serveur de conteneur Catalina.

L'architecture du logiciel se compose ainsi[7] :

  • Un serveur (server), soit tomcat en cours d'exécution ;
    • Des services, intermédiaires collectant différents canaux de transmissions vers un traitement ;
      • Un moteur (engine), qui pour chaque service traite les requêtes des collecteurs et renvoie les réponses ;
    • Des hôtes (host), qui relient une adresse réseau avec le serveur ;
    • Des connecteurs (connector), qui interprètent un canal et protocole de communication réseau à disposition des clients. Le connecteur HTTP est le plus typique ;
    • Des contextes (context), qui sont les applications web.

Le contexte est le lieu privilégié pour situer un service informatique que l'on veut rendre sur un réseau. Les autres modules sont mis en œuvre par le logiciel Tomcat lui-même.

Principe de fonctionnement[modifier | modifier le code]

Tomcat est souvent utilisé en association avec un autre serveur web plus généraliste[6], en général Apache, mais ce peut être aussi IIS :

  • Le serveur web s'occupe des pages web traditionnelles (.html, .php par exemple)
  • Il délègue à Tomcat les pages relevant spécifiquement d'une application web Java (Servlet, JSP...).

On peut utiliser le module mod jk pour réaliser la communication entre Apache et Tomcat. Techniquement, Apache communique alors avec Tomcat sur le port 8009 (via le protocole ajp13).

Pour l'administration à distance, Tomcat inclut des applications accessibles par HTTP[8].

Arborescence de répertoires[modifier | modifier le code]

L'installation par défaut de Tomcat comprend les répertoires suivants :

  • bin : scripts et exécutables pour différentes tâches comme le démarrage et l'arrêt, notamment le fichier catalina.sh qui permet le lancement et l'arrêt du serveur tomcat.
  • common : classes communes que Catalina et les applications Web utilisent.
  • conf : fichiers de configuration au format XML et les DTD que ces fichiers XML utilisent.
  • lib : le répertoire contenant les bibliothèques logicielles (fichiers .jar).
  • logs : journaux des applications Web et de Catalina, notamment le fichier catalina.out.
  • server : classes utilisées seulement par Catalina.
  • shared : classes partagées par toutes les applications Web.
  • webapps : répertoire contenant les applications web (fichiers .war).
  • work : fichiers et répertoires temporaires (le cache).

Historique[modifier | modifier le code]

Le projet Tomcat a été lancé comme implémentation de référence des servlets par James Duncan Davidson, architecte logiciel chez Sun. Il a contribué à rendre le projet libre et a joué un rôle majeur dans sa donation par Sun à la fondation Apache.

Davidson aspirait dès le départ à rendre le projet libre. Comme la plupart des projets libres sont associés à un livre O'Reilly avec un animal en couverture, il a souhaité donner un nom d'animal au projet. Il a choisi le nom Tomcat (« matou ») car cet animal représentait quelque chose qui peut prendre soin de lui-même [9]. Son souhait de voir une couverture d'animal s'est finalement concrétisé lorsque O'Reilly a publié un livre sur Tomcat avec un félin en couverture[10].

Bien qu'étant une implémentation de JEE moins complète que la plupart de ses concurrents, et même grâce à cette légèreté, Tomcat domine rapidement le marché des serveurs Java[11]. Il représentait en 2014 la moitié des utilisations de tels serveurs, plus précisément 59 % des sondés[12], loin devant JBoss et Jetty. En 2016, son utilisation baisse à 42 %, ce qui s'explique par la baisse du nombre de serveur d'application en production[13].

Fonctionnalités des versions[modifier | modifier le code]

Tomcat 3.x (version initiale)[modifier | modifier le code]

  • implémente les spécifications Servlet 2.2 et JSP 1.1 ;
  • rechargement des servlets ;
  • fonctionnalités HTTP de base.

Tomcat 4.x[modifier | modifier le code]

Tomcat 5.x[modifier | modifier le code]

Tomcat 6.x[modifier | modifier le code]

  • implémente les spécifications Servlet 2.5 et JSP 2.1 ;
  • support de Java 5 ;
  • amélioration de l'utilisation mémoire.

Tomcat 7.x[modifier | modifier le code]

  • implémente les spécifications Servlet 3.0, JSP 2.2 et EL 2.2;
  • support de Java 6 ;
  • amélioration de la détection et de la prévention des fuites de mémoire
  • mode hébergé simplifié

Tomcat 8.x[modifier | modifier le code]

  • implémente les spécifications Servlet 3.1, JSP 2.3, EL 3.0 et WebSocket 1.0;
  • support de Java 7 ;
  • amélioration des performances: la version par défaut des connecteurs est désormais basée sur des entrées/sorties Java non bloquantes (Asynchronous I/O) à la place des versions bloquantes (Blocking I/O)
  • amélioration de la sécurité

Tomcat 9.x[modifier | modifier le code]

Sont annoncés par la fondation Apache :

  • implémente Servlet 4.0 et WebSocket 1.1
  • support de Java SE 8 et + WebSocket 1.1
  • Améliorations de la stabilité de nombreuses API (javax, EL 3.0, Jasper 2, JSP 2.3...)

Voir aussi[modifier | modifier le code]

Sur les autres projets Wikimedia :

Articles connexes[modifier | modifier le code]

Liens externes[modifier | modifier le code]

Notes et références[modifier | modifier le code]

  1. (en) « Heritage » (consulté le )
  2. « https://projects.apache.org/json/projects/tomcat.json » (consulté le )
  3. « Tomcat 10.1.20 (schultz) », (consulté le )
  4. « Tomcat 11.0.0-M18 (markt) », (consulté le )
  5. Site officiel, « Apache Tomcat ».
  6. a et b (en) « Tomcat in the enterprise », sur javaworld.com, (consulté le )
  7. Site officiel, « Apache Tomcat Architecture ».
  8. « Utilisez le Tomcat Manager pour déployer vos projets web sur serveur Tomcat », sur java-hoster.com, (consulté le )
  9. Wiki Tomcat, « How did Tomcat get its name? ».
  10. livre sur Tomcat (en)
  11. (en) « Research Report Confirms Shift to Apache Tomcat », sur mulesoft.org, (consulté le )
  12. (en) « Java Tools and Technologies Landscape for 2014 », sur zeroturnaround.com, (consulté le )
  13. Java Tools and Technologies Landscape Report 2016