Apache Tomcat is a web server and servlet container that is used to serve Java applications. Tomcat is an open source implementation of the Java Servlet and JavaServer Pages technologies, released by the Apache Software Foundation.
This tutorial covers the basic installation and some configuration of Tomcat 7 with yum on your CentOS 7 server. Please note that this will install the latest release of Tomcat that is in the official Ubuntu repositories, which may or may not be the latest release of Tomcat. If you want to guarantee that you are installing the latest version of Tomcat, you can always download the latest binary distribution.
Note: Tomcat can be installed automatically on your Droplet by adding this script to its User Data when launching it. Check out this tutorial to learn more about Droplet User Data.
Before you begin with this guide, you should have a separate, non-root user account set up on your server. You can learn how to do this by completing the initial server setup for CentOS 7 tutorial. We will be using the demo
user for the rest of this tutorial.
Now you are ready to install Tomcat 7. Run the following command to install the Tomcat package:
Answer y
at the confirmation prompt to install tomcat. This will install Tomcat 7 and its dependencies, such as Java, and it will also create the tomcat
user.
Most of the important Tomcat files will be located in /usr/share/tomcat
. If you already have a Tomcat application that you want to run, you can place it in the /usr/share/tomcat/webapps
directory, configure Tomcat, and restart the Tomcat service. In this tutorial, however, we will install a few additional packages that will help you manage your Tomcat applications and virtual hosts.
Let’s make a quick change to the Java options that Tomcat uses when it starts. Open the Tomcat configuration file:
Add the following JAVA_OPTS
line to the file. Feel free to change the Xmx
and MaxPermSize
values—these settings affect how much memory Tomcat will use:
JAVA_OPTS="-Djava.security.egd=file:/dev/./urandom -Djava.awt.headless=true -Xmx512m -XX:MaxPermSize=256m -XX:+UseConcMarkSweepGC"
Save and exit.
Note that the Tomcat service will not be running yet.
If you are just getting started with Apache Tomcat, you will most likely want to install some admin tools that will help you deploy your Java applications and manage your virtual hosts. Luckily, there are packages that include these tools as web applications.
To install the default Tomcat root page (tomcat-webapps), and the Tomcat Web Application Manager and Virtual Host Manager (tomcat-admin-webapps), run this command:
Answer y
at the confirmation prompt.
This adds the ROOT
, examples
, sample
, manager
, and host-manager
web apps to the tomcat/webapps
directory.
If you want to install the Tomcat documentation, so that all of the links on the default Tomcat page will work, run this command:
Answer y
at the prompt to install the documentation packages.
In order to use the manager webapp installed in the previous step, we must add a login to our Tomcat server. We will do this by editing the tomcat-users.xml
file:
This file is filled with comments which describe how to configure the file. You may want to delete all the comments between the following lines, or you may leave them if you want to reference the examples:
<tomcat-users>
...
</tomcat-users>
You will want to add a user who can access the manager-gui
and admin-gui
(the management interface that we installed earlier). You can do so by defining a user similar to the example below. Be sure to change the username and password to something secure:
<tomcat-users>
<user username="admin" password="password" roles="manager-gui,admin-gui"/>
</tomcat-users>
Save and exit the tomcat-users.xml
file.
Now we’re ready to start the Tomcat service.
To put our changes into effect, restart the Tomcat service:
If you started the service earlier for some reason, run the restart command instead:
If you want Tomcat to run every time the server is booted up, you will need to enable the service:
Now we’re ready to access the web interface.
Now that Tomcat is up and running, let’s access the web management interface in a web browser. You can do this by accessing the public IP address of the server, on port 8080:
Open in web browser:http://server_IP_address:8080
You will see something like the following image:
As you can see, there are links to the admin webapps that you installed earlier.
Let’s take a look at the Manager App, accessible via the link or http://server_IP_address:8080/manager/html
:
The Web Application Manager is used to manage your Java applications. You can Start, Stop, Reload, Deploy, and Undeploy here. You can also run some diagnostics on your apps (i.e. find memory leaks). Lastly, information about your server is available at the very bottom of this page.
Now let’s take a look at the Host Manager, accessible via the link or http://server_IP_address:8080/host-manager/html/
:
From the Virtual Host Manager page, you can add virtual hosts to serve your applications from.
Your installation of Tomcat is complete! Your are now free to deploy your own Java web applications!
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
Hi,
After Installing Tomcat 7 , while running it I am reciveing a following page .please help me with that.
That type of error depends on your code. You might want to check that your server’s installed Java is supported by the application that you are trying to run. If not, install Java and update the value of
JAVA_HOME
in your Tomcat configuration.Hi ,
I have setup the demo user . But after executing the command 'sudo yum install tomcat ’ I am getting error as ‘No package Tomcat avaliable’, where am I going wrong…?
Are you on CentOS 7? If you’re using CentOS 6, the package name is “tomcat6”. So you might want to try:
So how does one go about installing tomcat7 on CentOS 6? Can this guide not be repurposed for that as well? Seems like the only issue is isolated to the YUM installer, is that right? I can’t accept that you need to rebuild your entire server to a more recent CentOS release to get this to work. Tomcat 7 should work on CentOS 6. Any assistance from anyone would be greatly appreciated…the application I’m running is only certified for CentOS 6 and Tomcat 7, I’ve seen it been done before, so I know its possible :)
UPDATE: Unless I misunderstood you and you mean that you literally have to type in “tomcat6” with YUM to install a Tomcat 7 package - (which makes absolutely no sense to me) - please clarify, thanks.
Nvm, figured it out folks
1.) Clear your screen (always good to start fresh)
2.) go to your home directory
3.) use
wget
to download directly from the Apache official archive (never understood why people have to use other sites and mirrors its the easiest thing to go directly to the official repo and grab the tarball, you can even download it to Windows and then FTP it by following the url link)4.) unzip the tar.gz and move it to a recommended directory
5.) At this point you should have everything you need to start, run, stop tomcat and you can get that info and more from this guide, or any other online forum out there :D
(here is the one I used though just for reference)
http://tecadmin.net/steps-to-install-tomcat-server-on-centos-rhel/#
@manicas Thankyou for your support, I was using Centos 6. I have rebuilt it to Centos 7 and now it is working fine.
Hi,
I am unable to access the tomcat manager app and host manager . I have run the
sudo vi /usr/share/tomcat/conf/tomcat-users.xml
command and added the code below to the file and saved it ., But still , I am not able to access. and it still asks for the username and password .
You should change the password (the “password” in quotes), then restart tomcat:
Then use the username (“admin”) and password (“password”) that you set.
i’m try restart after editing tomcat-users.xml, but /manager/html reject my login what i set
You say “We will be using the ‘demo’ user for the rest of this tutorial”. But the rest of the tutorial does not actually uses that username, nor explains how to tell tomcat under what user to run .
This is poorly written. For instance, does JAVA_OPTS=“-Djava.security.egd=file:/dev/./urandom -Djava.awt.headless=true -Xmx512m -XX:MaxPermSize=256m -XX:+UseConcMarkSweepGC” go in /etc/default/tomcat7 or /usr/share/tomcat/conf/tomcat.conf ?
I am looking to install a 2nd Tomcat instance on my CentOS droplet. How would I go about doing this?
Hi, After Installing Tomcat 7 , and start tomcat service, it failed with message:
Help me, Pls!