The moose likes IDEs, Version Control and other tools and the fly likes Using Eclipse with Tomcat and Sysdeo Plugin Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login
JavaRanch » Java Forums » Engineering » IDEs, Version Control and other tools
Bookmark "Using Eclipse with Tomcat and Sysdeo Plugin" Watch "Using Eclipse with Tomcat and Sysdeo Plugin" New topic

Using Eclipse with Tomcat and Sysdeo Plugin

Udit Manektala
Ranch Hand

Joined: Sep 17, 2006
Posts: 30
Im trying to get Eclipse to work with Tomcat using the Sysdeo plugin and have a few questions.

Firstly, I have already installed the Sysdeo plugin and can start\stop\restart Tomcat from Eclipse. So that works.
But here's the problem.

1. When I create a new Tomcat Project and put servlets with a web.xml, I can't
find a Deployment Button or anything. So I look around on the net and figure that I dont need to really Deploy anything, the plugin automagically places the files in the TomCat folder.
But when I try to acces the servlet at http://localhost:8080/XYZ/abc even though I have te right XYZ and abc, I still can't access it. So I look into the C:\tomcat\webapps folder and sure enough, that project is not there. Just for kicks, I copy my Web Project folder into the c:\Tomcat\Webapps folder and then I can access the servlet.

But how is this really supposed to work ? Should Sysdeo\Eclipse be placing the class files into the tomcat folder by itself or am i supposed to copy the project folder into the Tomcat\Webapps everytime I make a code change ?

If Its supposed to be copying the project files needed by itself then what couls I be doing wrong?
I have checked the Preferences Window and the path for the Tomcat folder is correct.
Ilja Preuss

Joined: Jul 11, 2001
Posts: 14112
There is no need to copy anything. A webapp doesn't really *need* to be located in the webapps folder - Tomcat is able to run it directly from the Eclipse workspace.

All you should need to do is right clicking on your new project, going into the tomcat submenu and there select the menu entry that reads something along the lines of "update context". That will register the context in Tomcat, telling it to look for the webapp in your project directory.

The soul is dyed the color of its thoughts. Think only on those things that are in line with your principles and can bear the light of day. The content of your character is your choice. Day by day, what you do is who you become. Your integrity is your destiny - it is the light that guides your way. - Heraclitus
Tim Holloway
Saloon Keeper

Joined: Jun 25, 2001
Posts: 17410

Not only doesn't a webapp not "need" to live in TOMCAT_HOME/webapps, there's a very good reason why it doesn't. There are occasionally times when it's useful to be running multiple copies of the same codebase - either for multiple Tomcat instances, or as alternate copies in the same instance, but with different setup parameters. Or both.

Although the feature first appeared in Tomcat4, in Tomcat5, the preferred deployment is not to merely plunk down a copy of the webapp codebase, but to formally define the application via a context file. In Tomcat5, that would be in TOMCAT_HOME/conf/Catalina/localhost. The context file defines the webapp context - including custom environment options and the location of the codebase. In Tomcat 5.0, I believe that WARs would be exploded into the TOMCAT_HOME/webapps directory, but this behaviour isn't something cast in stone. And in fact, caused me a log of grief, since Tomcat4 wasn't as likely to end up shoving stale classes down my throat.

In my own Eclipse projects, therefore, I define the web application context to point to my build/webapps directory, which is where I assemble the parts from which I will create the final WAR. This means that I only need to actually build the WAR itself when I'm ready to make a deployable unit, and that saves me some time.

An IDE is no substitute for an Intelligent Developer.
I agree. Here's the link:
subject: Using Eclipse with Tomcat and Sysdeo Plugin
It's not a secret anymore!