How to Install Tomcat 9 on CentOS 7
Updated on
•6 min read

Tomcat is an open-source implementation of the Java Servlet, JavaServer Pages, Java Expression Language, and Java WebSocket technologies.
This tutorial covers the steps required to install Tomcat 9.0 on CentOS 7.
Prerequisites
The user you are logging in as must have sudo privileges to be able to install packages.
Install OpenJDK
Tomcat 9 requires Java SE 8 or later. We will install OpenJDK, the open-source implementation of the Java Platform ,which is the default Java development and runtime in CentOS 7.
Install Java by typing the following command:
sudo yum install java-1.8.0-openjdk-devel
Create Tomcat system user
Running Tomcat as the root user is a security risk and not considered best practice.
We’ll create a new system user
and group with home directory /opt/tomcat
that will run the Tomcat service:
sudo useradd -m -U -d /opt/tomcat -s /bin/false tomcat
Download Tomcat
We will download the latest version of Tomcat 9.0.x from the Tomcat downloads page .
At the time of writing, the latest Tomcat version is 9.0.27
. Before continuing with the next step, you should check the Tomcat 9 download page to see if a newer version is available.
Navigate to the /tmp
directory and download the Tomcat zip file using the following wget command
:
cd /tmp
wget https://www-eu.apache.org/dist/tomcat/tomcat-9/v9.0.27/bin/apache-tomcat-9.0.27.tar.gz
When the download is complete, extract the tar file :
tar -xf apache-tomcat-9.0.27.tar.gz
Move
the Tomcat source files to it to the /opt/tomcat
directory:
sudo mv apache-tomcat-9.0.27 /opt/tomcat/
Tomcat 9 is updated frequently. To have more control over versions and updates, we’ll create a symbolic link called latest
, that points to the Tomcat installation directory:
sudo ln -s /opt/tomcat/apache-tomcat-9.0.27 /opt/tomcat/latest
The tomcat user that we previously set up needs to have access to the tomcat installation directory.
Run the following command to change the directory ownership to user and group tomcat:
sudo chown -R tomcat: /opt/tomcat
Make the scripts inside the bin
directory executable by issuing the following chmod
command:
sudo sh -c 'chmod +x /opt/tomcat/latest/bin/*.sh'
Create a systemd unit file
To make Tomcat run as a service open your text editor
and create a tomcat.service
unit file in the /etc/systemd/system/
directory:
sudo nano /etc/systemd/system/tomcat.service
Paste the following content:
[Unit]
Description=Tomcat 9 servlet container
After=network.target
[Service]
Type=forking
User=tomcat
Group=tomcat
Environment="JAVA_HOME=/usr/lib/jvm/jre"
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
Save and close the file.
Notify systemd that we created a new unit file by typing:
sudo systemctl daemon-reload
Enable and start the Tomcat service:
sudo systemctl enable tomcat
sudo systemctl start tomcat
Check the service status with the following command:
sudo systemctl status tomcat
● tomcat.service - Tomcat 9 servlet container
Loaded: loaded (/etc/systemd/system/tomcat.service; enabled; vendor preset: disabled)
Active: active (running) since Thu 2018-11-15 20:47:50 UTC; 4s ago
Process: 1759 ExecStart=/opt/tomcat/latest/bin/startup.sh (code=exited, status=0/SUCCESS)
Main PID: 1767 (java)
CGroup: /system.slice/tomcat.service
Adjust the Firewall
If your server is protected by a firewall
and you want to access the tomcat interface from the outside of the local network, you need to open port 8080
.
Use the following commands to open the necessary port:
sudo firewall-cmd --zone=public --permanent --add-port=8080/tcp
sudo firewall-cmd --reload
8080
only to your internal network.Configure Tomcat Web Management Interface
At this point Tomcat is installed, and we can access it with a web browser on port 8080
, but we can not access the web management interface because we have not created a user yet.
Tomcat users and their roles are defined in the tomcat-users.xml
file.
If you open the file, you will notice that it is filled with comments and examples describing how to configure the file.
sudo nano /opt/tomcat/latest/conf/tomcat-users.xml
To add a new user that will be able to access the tomcat web interface (manager-gui and admin-gui) you need to define the user in tomcat-users.xml
file as shown below. Make sure you change the username and password to something more secure:
<tomcat-users>
<!--
Comments
-->
<role rolename="admin-gui"/>
<role rolename="manager-gui"/>
<user username="admin" password="admin_password" roles="admin-gui,manager-gui"/>
</tomcat-users>
By default Tomcat web management interface is configured to allow access only from the localhost. If you want to be able to access the web interface from a remote IP or from anywhere which is not recommended because it is a security risk you can open the following files and make the following changes.
If you need to access the web interface from anywhere open the following files and comment or remove the lines highlighted in yellow:
<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>
<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>
If you need to access the web interface only from a specific IP, instead of commenting the blocks add your public IP to the list.
Let’s say your public IP is 41.41.41.41
and you want to allow access only from that 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|41.41.41.41" />
</Context>
<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|41.41.41.41" />
</Context>
The list of allowed IP addresses is a list separated with vertical bar |
. You can add single IP addresses or use a regular expressions.
Once done, restart the Tomcat service for changes to take effect:
sudo systemctl restart tomcat
Test the Installation
Open your browser and type: http://<your_domain_or_IP_address>:8080
Upon successful installation, a screen similar to the following should appear:

Tomcat web application manager dashboard is available at http://<your_domain_or_IP_address>:8080/manager/html
. From here, you can deploy, undeploy, start, stop, and reload your applications.

Tomcat virtual host manager dashboard is available at http://<your_domain_or_IP_address>:8080/host-manager/html
. From here, you can create, delete, and manage Tomcat virtual hosts.

Conclusion
You have successfully installed Tomcat 9.0 on your CentOS 7 system and learned how to access the Tomcat management interface. You can now visit the official Apache Tomcat 9.0 Documentation and learn more about the Apache Tomcat features.
If you hit a problem or have feedback, leave a comment below.