Tomcat

TODO: add info on logs, environment variables

Basics

Tomcat is the server program responsible for providing the interactive interface of the e-Labs. Technically, it's a Java "Servlet Container." In more modern terms, it's something like an early Java web framework that converts Java ServerPages (JSP) files and special Java files called "Servlets" into HTML.

Usage

Tomcat runs on the main server VMs i2u2-prod and i2u2-dev, which use the Ubuntu OS. If you set up a local development environment, you'll also need to run Tomcat on your machine. We recommend Ubuntu for this for consistency, though we have some experience using OS X/macOS.

On all systems, Tomcat can be manipulated through its included catalina.sh script

OS location
Ubuntu 14-20 /usr/share/tomcat{X}/bin/catalina.sh
OS X El Capitan /usr/local/apache-tomcat-{X}/bin/catalina.sh
(Replace {X} with the appropriate version for your situation) with the commands

$ sudo /path/to/catalina.sh (start | stop | version)

However, Ubuntu has shortcut commands that you'll use more frequently.

Tomcat on Linux

We've installed and used various versions of Tomcat on Ubuntu 14, Ubuntu 16, and Fedora 23 Linux. Ubuntu usually refers to Tomcat using its version number: tomcat7, tomcat8, e.g., while Fedora drops the number, using simply tomcat. Otherwise there's little difference between the two.

Ubuntu 14.04 runs Tomcat as a System V service (called Upstart), meaning that there will exist a directory /etc/init.d/ containing control scripts (/etc/init.d/tomcat{X}/ for Tomcat) that streamline interaction with its processes. These are accessed with commands such as
$ sudo service tomcat{X} (start | stop | status | restart)

You may also see people accessing the init scripts directly with

$ sudo /etc/init.d/tomcat{X} (start | stop | status | restart)

though there's not really any good reason to do this as far as I can tell.

Ubuntu 16.04 (and higher) and Fedora 23 use the newer systemd structure with systemctl syntax,

$ sudo systemctl (start | stop | status | restart) tomcat.service

The /etc/init.d/ directories continue to exist on both Ubuntu (up to 20.04, at least) and Fedora 23, and the older System V service commands still work on both, but they redirect to systemd commands. Expect the System V structure to disappear in the next few years with future versions of these distributions.

Tomcat on OS X (El Capitan)

The catalina.sh script commands

$ sudo /usr/local/apache-tomcat-{X}/bin/catalina.sh (start | stop | version)

can be used to manage Tomcat, with the meaning of each option hopefully obvious. You can add the script's directory to your PATH variable for convenience; otherwise you'll need to specify the absolute filepath when you invoke it.

The directory /usr/local/apache-tomcat-{X}/ is what we symlink as ~/quarkcat/sw/tomcat when setting up a local development environment, so you'll also be able to use
$ sudo ~/quarkcat/sw/tomcat/bin/catalina.sh (start | stop | version)

This is the only practical way to work with Tomcat on OS X. Note that catalina.sh doesn't have a restart command. To restart, you'll have to use stop and then start in succession. There's also no status command; to see if Tomcat is running from the command line, use
$ ps aux | grep catalina

($ ps aux | grep tomcat should also work). A running Tomcat process will be a lengthy entry ending in org.apache.catalina.startup.Bootstrap start.

Directories and Settings

This section is limited to the file structure and settings files of Tomcat on Ubuntu.

Webapp Files

The Tomcat "server" directory is /var/lib/tomcat{X}/webapps/. By default, Tomcat considers any folder within this directory to be a webapp. For example, the directory /var/lib/tomcat{X}/webapps/elabs/ is the e-Labs webapp; files within this folder are the "live" files used to deliver the e-Labs to the user's browser.

On the server VMs (and on a local development environment), we symlink the folder /var/lib/tomcat{X}/ to ~quarkcat/sw/tomcat/. I'm not certain if there's a technical reason for this, but it does conveniently make all the e-Labs files you need to work with available within the ~quarkcat/ user directory at ~quarkcat/sw/tomcat/webapps/elabs/.

Server Settings

Global settings for Tomcat are contained in the server.xml file at /etc/tomcat{X}/server.xml

-- Main.JoelG - 2016-05-05

Comments

 
</verbatim>
Topic revision: r9 - 2021-03-09, JoelG
This site is powered by FoswikiCopyright © by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding Foswiki? Send feedback