Apache Tomcat est une implémentation open source des technologies Java Servlet, JavaServer Pages, Java Expression Language et Java WebSocket. C'est l'une des applications et des serveurs Web les plus largement adoptés dans le monde aujourd'hui. Tomcat est simple à utiliser et dispose d'un solide écosystème de modules complémentaires.
Ce tutoriel montre comment installer Tomcat 8.5 sur Ubuntu 18.04. Les mêmes instructions s'appliquent à Ubuntu 16.04 et à toute distribution basée sur Ubuntu, y compris Linux Mint et Elementary OS.
Prérequis #
Avant de poursuivre ce didacticiel, assurez-vous que vous êtes connecté en tant qu'utilisateur disposant des privilèges sudo.
Installer OpenJDK #
OpenJDK, l'implémentation open source de la plate-forme Java, est le développement et l'exécution Java par défaut dans Ubuntu 18.04.
L'installation du package OpenJDK est assez simple :
sudo apt install default-jdk
Créer un numéro d'utilisateur Tomcat
Nous allons créer un nouvel utilisateur système et un groupe avec le répertoire personnel /opt/tomcat
qui exécutera le service Tomcat :
sudo useradd -m -U -d /opt/tomcat -s /bin/false tomcat
Télécharger Tomcat #
Nous utiliserons wget
et unzip
pour télécharger et extraire l'archive Tomcat. Si vous n'avez pas unzip
et wget
installé sur votre système installez les packages avec :
sudo apt install unzip wget
Téléchargez la dernière version de Tomcat 8.5.x à partir de la page de téléchargement de Tomcat. Au moment de la rédaction, la dernière version est la 8.5.37. Avant de passer à l'étape suivante, vous devez vérifier la page de téléchargement pour une nouvelle version.
Passez au /tmp
répertoire et téléchargez le fichier zip avec la commande wget suivante :
cd /tmp
wget http://www-us.apache.org/dist/tomcat/tomcat-8/v8.5.37/bin/apache-tomcat-8.5.37.zip
Une fois le téléchargement terminé, décompressez le fichier et déplacez-le vers /opt/tomcat
répertoire :
unzip apache-tomcat-*.zip
sudo mkdir -p /opt/tomcat
sudo mv apache-tomcat-8.5.37 /opt/tomcat/
Afin d'avoir plus de contrôle sur les versions et les mises à jour, nous allons créer un lien symboliquelatest
qui pointera vers le répertoire d'installation de Tomcat :
sudo ln -s /opt/tomcat/apache-tomcat-8.5.37 /opt/tomcat/latest
Plus tard, si vous souhaitez mettre à niveau votre installation Tomcat, vous pouvez simplement décompresser la version la plus récente et modifier le lien symbolique pour qu'il pointe vers la dernière version.
L'utilisateur tomcat que nous avons précédemment configuré doit avoir accès au répertoire tomcat, nous allons donc changer la propriété du répertoire en utilisateur et groupe tomcat :
sudo chown -R tomcat: /opt/tomcat
Créez les scripts dans bin
répertoire exécutable en exécutant le chmod
suivant commande :
sudo sh -c 'chmod +x /opt/tomcat/latest/bin/*.sh'
Créer un fichier d'unité systemd #
Pour exécuter Tomcat en tant que service, nous allons créer un nouveau tomcat.service
fichier d'unité dans le /etc/systemd/system/
répertoire avec le contenu suivant :
[Unit]
Description=Tomcat 8.5 servlet container
After=network.target
[Service]
Type=forking
User=tomcat
Group=tomcat
Environment="JAVA_HOME=/usr/lib/jvm/default-java"
Environment="JAVA_OPTS=-Djava.security.egd=file:///dev/urandom"
Environment="CATALINA_BASE=/opt/tomcat/latest"
Environment="CATALINA_HOME=/opt/tomcat/latest"
Environment="CATALINA_PID=/opt/tomcat/latest/temp/tomcat.pid"
Environment="CATALINA_OPTS=-Xms512M -Xmx1024M -server -XX:+UseParallelGC"
ExecStart=/opt/tomcat/latest/bin/startup.sh
ExecStop=/opt/tomcat/latest/bin/shutdown.sh
[Install]
WantedBy=multi-user.target
Avertissez systemd que nous avons créé un nouveau fichier d'unité et démarrez le service Tomcat en exécutant :
sudo systemctl daemon-reload
sudo systemctl start tomcat
Vous pouvez vérifier l'état du service avec la commande suivante :
sudo systemctl status tomcat
● tomcat.service - Tomcat 8.5 servlet container
Loaded: loaded (/etc/systemd/system/tomcat.service; disabled; vendor preset: enabled)
Active: active (running) since Sat 2018-05-05 11:04:40 UTC; 5s ago
Process: 13478 ExecStart=/opt/tomcat/latest/bin/startup.sh (code=exited, status=0/SUCCESS)
Main PID: 13499 (java)
Tasks: 45 (limit: 507)
CGroup: /system.slice/tomcat.service
└─13499 /usr/lib/jvm/default-java/bin/java -Djava.util.logging.config.file=/opt/tomcat/latest/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.security.
et s'il n'y a pas d'erreurs, vous pouvez activer le démarrage automatique du service Tomcat au démarrage :
sudo systemctl enable tomcat
Ajuster le pare-feu #
Si votre serveur est protégé par un pare-feu et que vous souhaitez accéder à l'interface tomcat depuis l'extérieur de votre réseau local, vous devrez ouvrir le port 8080
.
Pour autoriser le trafic sur le port 8080
tapez la commande suivante :
sudo ufw allow 8080/tcp
Lors de l'exécution d'une application Tomcat dans un environnement de production, vous aurez très probablement un équilibreur de charge ou un proxy inverse et il est recommandé de restreindre l'accès au port 8080 uniquement à votre réseau interne. Configurer l'interface de gestion Web Tomcat #
Maintenant que Tomcat est installé sur notre serveur Ubuntu, la prochaine étape consiste à créer un utilisateur qui aura accès à l'interface de gestion Web.
Les utilisateurs Tomcat et leurs rôles sont définis dans le tomcat-users.xml
fichier.
Si vous ouvrez le fichier, vous remarquerez qu'il est rempli de commentaires et d'exemples décrivant comment configurer le fichier.
sudo vim /opt/tomcat/latest/conf/tomcat-users.xml
Pour ajouter un nouvel utilisateur pouvant accéder à l'interface Web de Tomcat (manager-gui et admin-gui), nous devons définir l'utilisateur dans le tomcat-users.xml
fichier comme indiqué ci-dessous. Assurez-vous de changer le nom d'utilisateur et le mot de passe pour quelque chose de plus sûr :
<tomcat-users>
<!--
Comments
-->
<role rolename="admin-gui"/>
<role rolename="manager-gui"/>
<user username="admin" password="admin_password" roles="admin-gui,manager-gui"/>
</tomcat-users>
Par défaut, l'interface de gestion Web de Tomcat est configurée pour autoriser l'accès uniquement à partir de l'hôte local. Si vous souhaitez pouvoir accéder à l'interface Web à partir d'une adresse IP distante ou de n'importe où, ce qui n'est pas recommandé car il s'agit d'un risque de sécurité, vous pouvez ouvrir les fichiers suivants. et apportez les modifications suivantes.
Si vous avez besoin d'accéder à l'interface Web de n'importe où, ouvrez les fichiers suivants et commentez ou supprimez les lignes surlignées en jaune :
/opt/tomcat/latest/webapps/manager/META-INF/context.xml<Context antiResourceLocking="false" privileged="true" >
<!--
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />
-->
</Context>
/opt/tomcat/latest/webapps/host-manager/META-INF/context.xml<Context antiResourceLocking="false" privileged="true" >
<!--
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />
-->
</Context>
Si vous avez besoin d'accéder à l'interface Web uniquement à partir d'une adresse IP spécifique, au lieu de commenter les blocs, ajoutez votre adresse IP publique à la liste. Supposons que votre adresse IP publique soit 32.32.32.32
et vous souhaitez autoriser l'accès uniquement à partir de cette adresse IP :
<Context antiResourceLocking="false" privileged="true" >
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1|32.32.32.32" />
</Context>
/opt/tomcat/latest/webapps/host-manager/META-INF/context.xml<Context antiResourceLocking="false" privileged="true" >
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1|32.32.32.32" />
</Context>
La liste des adresses IP autorisées est une liste séparée par une barre verticale |
. Vous pouvez ajouter des adresses IP uniques ou utiliser des expressions régulières.
Redémarrez le service Tomcat pour que les modifications prennent effet :
sudo systemctl restart tomcat
Tester l'installation #
Ouvrez votre navigateur et tapez :http://<your_domain_or_IP_address>:8080
En supposant que l'installation est réussie, un écran semblable au suivant apparaît :
Le tableau de bord du gestionnaire d'applications Web Tomcat est disponible sur http://<your_domain_or_IP_address>:8080/manager/html
. À partir de là, vous pouvez déployer, annuler le déploiement, démarrer, arrêter et recharger vos applications.
Le tableau de bord du gestionnaire d'hôte virtuel Tomcat est disponible sur http://<your_domain_or_IP_address>:8080/host-manager/html
. À partir de là, vous pouvez créer, supprimer et gérer des hôtes virtuels Tomcat.