webMathematica requires that Java, a Servlet container and Mathematica are installed on the system. Certain functionality in Mathematica, and hence webMathematica, requires the use of Mathematica's front end. The front end in turn requires an X Window System on Linux. The steps to install webMathematica are as follows:
- Setting Up Java
- Setting Up Tomcat
- Setting Up Mathematica
- Making Licensing Files Accessible to the “Tomcat” User
- Installing and Setting Up webMathematica
- Configuring Xvnc for Minimal or Server Editions of Linux
Java is required not only for webMathematica but also for any Java Servlet container. You can access Oracle’s Java from http://www.oracle.com/us/downloads/index.html.
In several Linux distributions, Java packages can also be installed via either the command line or through their software centers:
To verify the successful installation, on the command line, execute:
webMathematica is designed to operate from within a Java Servlet container. Among various available Servlet containers, we provide limited guidance with Apache Tomcat only.
- Go to http://tomcat.apache.org/download-80.cgi.
- Download the installer in the format apache-tomcat-N.M.QQ.tar.gz, where N.M.QQ represents the Tomcat version number you downloaded.
- In the location you wish to install the server, execute:
Creating a Tomcat Account
It is recommended that you set up a separate account to run the server under, which we name “tomcat”. This account needs the permissions to run webMathematica.
- To create the account, execute in the terminal:
- Change the ownership and group of the Tomcat installation directory to the “tomcat” user by executing these commands from the parent directory where you installed the apache-tomcat server:
- To start the Tomcat server, in the Tomcat installation directory, execute:
- Open a web browser and submit “localhost:8080”. If Tomcat has been set up correctly, a page similar to the following one appears:
Common possible issues:
- The computer’s firewall is blocking requests to Tomcat. Tomcat, by default, runs on port 8080. Ensure that the port is open to accept tcp packets on the system running the tomcat server.
- If you downloaded Java from Oracle’s website, the Tomcat server may not be able to find the Java installation. In such a case, set the system variable JAVA_HOME to Java’s installation directory, e.g. by executing the following on a bash command line or by adding these lines to .bashrc, if your Java was installed in
Setting up Mathematica requires installing the program, activating it with your activation key and moving the generated licensing information into a location that makes it accessible globally on the machine in question.
Install Mathematica by running the Linux installer with the following command. Ensure you use the appropriate file name:
Take note of the installation directory you choose if you do not use the default.
On Linux systems without X Window installed, the Mathematica front end will not be available. Instead, activate Mathematica through the kernel.
- Execute the following command:
- Enter your activation key. Note the activation key has the form XXXX-XXXX-XXXXXX.
By default, Mathematica places its licensing information in a mathpass file in a user-specific location. To make your licensing information accessible to your “tomcat” account, copy the mathpass file into the globally accessible base directory of Mathematica and set its permission so that any account can read the file.
- To identify the location of your mathpass file, evaluate in Mathematica:
- To identify the base directory location, evaluate:
These folder locations are used in the following instructions.
- The Licensing directory may not yet exist. If so, create it by executing the following command:
- Copy the mathpass file to the Licensing directory of the base directory:
- Grant read access to the mathpass file for all accounts:
webMathematica's installation files contain webMathematica.zip. Place it into the webapps directory of your Apache Tomcat servers and unzip the file to ensure it is opened and unpacked at startup. Assuming that you have defined
$TOMCAT_INSTALL to represent the installation directory of your Tomcat server, evaluate the following:
Testing and Troubleshooting
The webMathematica package comes with some default pages that can be used to test the setup of webMathematica.
- Access the base page by pointing a browser to “localhost:8080/webMathematica”.
- As a first test, click the Hello World example. The Hello World page providing the current time and date appears.
- If Hello World is not working, check the log file by executing:
Common possible issue:
Search the above log file for error
....com.wolfram.kerneltools.state.StateMachine . In such a case, webMathematica could not find the executable of the Mathematica kernel. This can occur if you have installed Mathematica in a non-standard location or if a version of webMathematica is not paired with the recommended Mathematica version, e.g. webMathematica 3.4.3 was released for Mathematica 11.3 and looks in the default installation directory of Mathematica for the executable.
To point to the correctly paired version of Mathematica, configure webMathematica.
- On the command line, go to
$TOMCAT_INSTALL/webapps/webMathematica/WEB-INF/and locate the file
- Open MSPConfiguration.xml in a text editor and locate the following section:
- Edit and change this section to:
Note: These instructions assume Mathematica 11.x was installed to
/usr/local/Mathematica/11.x/. If you have a different installation directory, substitute the installation directory you used.
Many “Server” or “Minimal” distributions of Linux do not include an X Window server by default. Some Mathematica functionality and thus some webMathematica functionality requires an X Window server to be available. For instance, the Plot Example cannot execute properly without an X Window system of some sort. For these purposes, it is recommended that you run an Xvnc server.
- Install an Xvnc server, which can commonly be obtained through command line install applications like yum or apt-get.
- Launch a vnc display with the command “vncserver”. This will initially require you to provide a display number (typically 1).
- Configure webMathematica to use the display by editing the file
$TOMCAT_INSTALL/webapps/webMathematica/WEB-INF/MSPConfiguration.xmlto include the following code: