Debugging Tomcat Remotely Using Eclipse
Debugging Tomcat as a Remote External Application
Eclipse can be configured to provide debugging information for a running tomcat instance that is configured with JPDA support. This approach may work better for users using Windows.
Instructions for setting up tomcat to use JPDA.
Once you have tomcat configured:
- Start tomcat manually from the command line.
- Set a breakpoint somewhere in your code (preferably something not associated with startup) by left-clicking to the left of a line of code.
- Under the "Run" menu, select "Debug"
- Single-click the heading "Remote Java Application", then press the new button (looks like a page with a plus on it).
- On the dialog that appears, enter a meaningful name (like "Sakai (remote)" for this configuration).
- From the same dialog, change to the "Source" tab, then click "Add".
- On the dialog that appears, single-click "Java Project", then click "OK".
- On the dialog that appears, click "Select All" (or check the projects you wish to import), then click "OK".
- Now click the "Connect" tab and check the box marked "Allow termination of remote JVM".
- Click "Apply" to save your changes.
- Click "Debug" to start testing your configuration.
- Open your browser and work with Sakai until you reach your breakpoint. You should be directed into Eclipse where you will see the line of code with your breakpoint, a list of variables, etc., etc.
If you do not see the console output when using this method, you can simply keep open a separate window that displays the last contents of catalina.out.
Debugging Tomcat as an External Tool from within Eclipse
You can also configure Eclipse to be able to start and stop tomcat as a program (this approach also seems to work well on Windows). To configure Eclipse to be able to start and stop tomcat:
If you have already completed the above steps, you will need to stop tomcat to use the steps below.
- If you have not already done so, set a breakpoint somewhere in your code (preferably something not associated with startup) by left-clicking to the left of a line of code.
- Under the "Run" menu, select the "External Tools" sub-menu, then the "External Tools" heading.
- On the dialog that appears, single-click the "Program" heading, then click the "New" icon (a page with a plus on it).
- Change the Name to something meaningful, like "Sakai 2.4".
- Under "Location", enter full path and filename for your catalina script (catalina.sh on UNIX, catalina.bat on Windows).
- Under "Working Directory" to the location of your tomcat installation.
- Under "Arguments", enter "jpda start".
- NOTE: If you use "jdpa run" rather than "jpda start", Tomcat will not open a new window to start in and will instead give you all it's standard err and standard out in the Eclipse console window. This is usefull for Windows developers who don't like to read console output from a DOS window.
- Go to the "Environment" tab.
- Click "New" and enter "JPDA_ADDRESS" as the name and "8000" as the value, then hit "OK".
- Click "New" again and enter "JPDA_TRANSPORT" as the name and "dt_socket" as the value, then hit "OK".
- Click "New" again and enter "JAVA_OPTS" as the name and "-server -XX:+UseParallelGC -Xmx768m -XX:MaxPermSize=160m -Djava.awt.headless=true" as the value, then hit "OK".
- Open the "Common" tab.
- Check the box marked "External Tools" in the panel marked "Display in favorites menu".
- Check the box marked "Launch in background".
- Hit "Apply" to save your changes.
- Hit "Run" to test your configuration.
- Once Sakai finishes starting up, open your browser and work with Sakai until you reach your breakpoint. You should be directed into Eclipse where you will see the line of code with your breakpoint, a list of variables, etc., etc.
Once you exit the debugger and stop tomcat, you should be able to start and stop tomcat with debugging enabled from within Eclipse by opening the "Run" menu and selecting "External Tools". You can also begin debugging your code by opening the "Run" menu and selecting "Debug".
tomcat will start when you run it as an external tool, but you will probably not see console output. You'll need to open another window that contains the contents of catalina.out to keep track of the startup or use jpda run
Configuring Tomcat as a Known Server from within Eclipse
You can also configure Eclipse to be able to start and stop tomcat as a server (this approach seems to work well on Unix). To configure Eclipse to be aware of tomcat as a server:
If you have already completed the above steps, you will need to stop tomcat to use the steps below.
- Edit ~/eclipse/eclipse.ini and change the memory settings as follows:
-vmargs -Xms256m -Xmx1024m
- NOTE: Eclipse has to have enough available memory to actually run Sakai within it
- If you have not already done so, set a breakpoint somewhere in your code (preferably something not associated with startup) by left-clicking to the left of a line of code.
- Configure Eclipse to launch the desired JVM with the appropriate memory settings:
- Under the "Eclipse" menu, select "Preferences"
- Open the "Java" heading and the "Installed JREs" subheading.
- Single-click the desired run-time, then click "Edit".
- Under "Default VM Arguments", enter "-server -XX:+UseParallelGC -Xmx1024m -XX:MaxPermSize=384m -Djava.awt.headless=true", then click "OK".
- Click "OK" again to close the preferences dialog.
- Add the Sakai tomcat instance to the list of known runtimes:
- Under the "Eclipse" menu, select "Preferences"
- Expand the "Server" heading on the left side of the dialog that appears, then single-click "Installed Runtimes" and click "Add".
- On the dialog that appears, expand the Apache heading, then single-click "Apache Tomcat v5.5" and click "Next".\
- Under "Name", enter something meaningful like "Sakai 2.4 tomcat".
- Under "Tomcat installation directory", enter the location of your tomcat home directory.
- Under "JRE", select the JVM you configured above.
- Click "Finish".
- Add the server to the debug view
- Open the "Debug" view.
- Open the "Servers" tab.
- Using the right mouse button (or control-click on the mac), open the dialog to create a new server.
- Under "Server's host name", fill in "localhost" if it doesn't already appear.
- Open the "Apache" heading, then select "Tomcat v5.5 Server".
- Under "Server Runtime", select the runtime you defined earlier.
- Click "Finish" (you're not actually finished )
- Double-click the new server entry, a dialog should appear with more advanced options.
- Change "Server name" to something meaningful like "Sakai 2.4 (Server)".
- Uncheck "Run modules directly from the workspace".
- Click "Open launch configuration".
- On the dialog that appears, open the "Arguments" tab. Change "program arguments" to "jpda start".
- NOTE: If you use "jdpa run" rather than "jpda start", Tomcat will not open a new window to start in and will instead give you all it's standard err and standard out in the Eclipse console window. This is usefull for Windows developers who don't like to read console output from a DOS window.
- On the same dialog, change "VM arguments" so that catalina.base is set to the tomcat home directory.
- Open the "Source" tab, then click "Add".
- On the dialog that appears, single-click "Java Project", then click "OK".
- On the dialog that appears, click "Select All", then click "OK".
- Open the "Environment" tab, then click "New".
- Enter "JPDA_ADDRESS" for "Name", and "8000" for "Value", then click "OK".
- Click "Add" again, then enter "JPDA_TRANSPORT" for "Name" and "dt_socket" for "Value". Click "OK".
- Click "Apply", then "OK" to save your launch settings.
- IMPORTANT: Under the "File" menu, select "Save" to save your overall server definition.
- You should now be able to start up the server by right clicking (or control clicking) its heading in the "Servers" tab and selecting "Start".
- Once Sakai finishes starting up, open your browser and work with Sakai until you reach your breakpoint. You should be directed into Eclipse where you will see the line of code with your breakpoint, a list of variables, etc., etc.