This topic describes how to set up and use a Tomcat server with the BEA Workshop Studio family of products. The topics discussed here are:
This topic assumes that you already have a server installed locally on your development machine, or on a server available for development. For information on installing, setting up and managing the server, consult the Tomcat documentation.
To define a server:
Choose the server by expanding Apache and choosing the appropriate server. Click Next to continue.
Note that you must specify the full JDK (not just the JRE that is the default).
Fill in the appropriate values and click Finish to continue.
Note that the first project is automatically selected in the Select Project to Debug field. You can use the pull-down to specify which project will be debugged.
Only one project at a time can be debugged on the server. The project that is currently allowed to run in debug mode is the project displayed in the Select Project to Debug field. You are not required to run this project in debug mode, but if you wish to debug another project on the server, you must change this setting before debugging the application.
To update the definition for a server:
Running and debugging applications is the same for all servers.
Manual deployment is not supported on Tomcat servers.
To debug on a remote server (or on a local server which is started and managed OUTSIDE of the IDE), you must configure the server for remote debugging, deploy the application manually and then define the remote server's address.
Configuring the server for remote debugging is a feature of the server. This information is provided for your convenience. For definitive documentation, consult your server documentation.
For Tomcat 4.1.x, the IDE uses standard JPDA and self-generated line maps.
For Tomcat 5.x, the IDE uses standard JPDA and self-generated line maps. The JSR-45 debug information has to be disabled by placing the following servlet in the application web.xml file:
<servlet> <servlet-name>nitrox-debugger-tomcat5</servlet-name> <description>Added to compile JSPs without JSR-045 debug info</description> <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class> <init-param> <param-name>suppressSmap</param-name> <param-value>true</param-value> </init-param> <load-on-startup>3</load-on-startup></servlet> <servlet-mapping> <servlet-name>nitrox-debugger-tomcat5</servlet-name> <url-pattern>*.jsp</url-pattern></servlet-mapping>
Open \Tomcat 5.0\bin\catalina.bat (or \Tomcat 4.x\bin\catalina.bat) on Windows or the equivalent shell script on Unix and define environment variable at the start of the BAT file:
set JPDA_TRANSPORT=dt_socket set JPDA_ADDRESS=8453
Start the Tomcat server using following command:
catalina.bat jpda start
The Tomcat Server console should display this message:
Listening for transport dt_socket at address: 8453
Tomcat 5.5 no longer ships catalina.bat on Windows platform. You can reuse the batch files from the Tomcat 5.0 release by copying over catalina.bat, setclasspath.bat . A Windows application called tomcat5w.exe shipped in Tomcat 5.5 is supposed to provide users a GUI to customize the Tomcat Server startup parameters. But in our test, adding the following in the tab Java > Java Options
-Xrunjdwp:transport=dt_socket,address=8453,server=y,suspend=n
to enable remote debug did not seem to work.
Before attempting to debug an application on a remote server, you must:
When remote debugging an application on a physically separate machine, the debugger will hit JSP breakpoints but the IDE will not show the correct source line in JSP, becasue Workshop Studio is trying to locate JSP servlet source for line mapping but the files are not available to the IDE.
To enable source debugging of servlets on a separate server, map the following directory (on the remote server) to a local directory, and use the Source Lookup Path dialog, or the Source tab in the Launch Configuration dialog (the Run > Run command), to add the mapped directory to Source Lookup Path.
For Tomcat, all versions, map the directory
$CATALINA_BASE\work\Catalina\localhost\_
e.g:
C:\Tomcat 5.0\work\Catalina\localhost\_
To define a remote server:
Change the Connection Type to Standard (Socket Attach) and specify the Host and Port.
Note that when debugging an application on a remote server, you must not disable the Run module directly from the workspace option when you update server settings.