Working with the Jakarta NT Service
By Gal Shachor
<shachor@il.ibm.com>
The Jakarta NT service is an executable that wraps the
Tomcat servlet container and executes it in the background as an NT service. To
install it you will need to:
- Get a
hold on the NT executable (jk_nt_service.exe)
- Customize
a properties file that provides the service with Tomcat information
(wrapper.properties).
- Install
jk_nt_service by running it with the -i flag.
- Execute
jk_nt_service -I <name of service> <path to updated wrapper
properties>
- <name
of service> should be a single word (without and spaces) such as
Jakarta
- <path
to updated wrapper properties> should point to your wrapper.properties
file (and the service will check it's existence.)
- For
example, a valid command line can be jk_nt_service -I Jakarta wrapper.properties
- Start
tomcat as a service.
- From
the command line, execute net start <name of service> (e.g. net
start Jakarta)
- From
the NT services applet, highlight your service and press start.
- Stop
Tomcat as a service.
- From
the command line, execute net stop <name of service> (e.g. net
stop Jakarta)
- From
the NT services applet, highlight your service and press stop.
Special note: The Tomcat service is using AJPV12 to
perform clean shutdown and you should make sure that an AJPV12 connector is
defined in your server.xml. In the absence of a configured AJPV12 port the
Tomcat service will kill Tomcat abruptly (that is murder it) without giving it
a chance to clean up.
Advance Setup
- Modify
the Tomcat NT service properties. By default the service will run in manual
mode and under the local system user account. To modify this, open the NT
services applet, highlight your service and press startup. A popup window
is opened and you will be able to customize the service to your
satisfaction.
- Modify
the classpath. The classpath is determined by the wrapper.class_path
properties, to modify it just add/remove/modify wrapper.class_path lines.
The complete classpath is calculated by concatenating all the
wrapper.class_path lines and putting ";" between them.
- Execute
several Tomcat instances. Say that you want one Tomcat to run for
"production" and one for development, you can do that. All you
will need to do is to install the Tomcat service twice and under two
different names (and with different wrapper.properties file and server.xml
files).
- Make
sure that the AJPV12 and HTTP connectors are modified in each server.xml
file to prevent a clash.
- Make
sure to update the wrapper.shutdown_port property in wrapper.properties
to point to the correct AJPV12 shutdown ports (default is 8007).
- Modify
the command line used to start Tomcat. The Tomcat service is taking all
it's command line configuration from wrapper.properties! To customize the
command line, edit the property wrapper.cmd_line and make sure that it
makes a legal Java command line.
Feedback
Please send feedback, bug report or any additional information to
<tomcat-user@jakarta.apache.org>