I've been given a web app to do for an open source driven organization. I like the ideology behind open source, but I must say that the complexities involved in just getting started, must be the single biggest hurdle in the adoption of OSS.
Most Java and Linux fanboys might rupture a vain for me saying this, but to get any sort of Java web app going is massive pain in butt. To get Asp.Net going, one merely install visual studio and off you go. You don't even need IIS these days. To get a Java web app (dev environment) going you have to install a web server, an application server, a java framework, an IDE, IDE plugins to support the java framework and perhaps additional frameworks / tools which will allow you to work in a "code-behind" fashion. Then you have to decide on a web frameworks and the choices are endless: Spring MVC, Struts, Seam, JSF, Tapestry, Wicket, Hibernate, Stripes, etc. You can Google until you're blue in the face, but every single framework claims to be the best and all have their own following of groupies. To be honest, it is a big geeky mess!
Unfortunately I don't have the luxury of cleaning up this steaming pile of
rubbish, so I'll have to get my hands dirty and figure out what the best solution is through trial and error (very scientific).
My client already has Tomcat running, so luckily I don't have to bother about figuring out which application server is the best. A further requirement is that the web framework should be quite lightweight. It seems as if JBoss' Seam framework isn't too much of a brute, so I'll go with that and probably get burned half-way in.
Even though I detest overcomplicated systems, I've grown quite fond of Gentoo. Once you've mastered this beast, it is quite pleasant to work with. (Perhaps I'll have the same feelings towards Java web apps once I've finished here, but for now it's not looking good.) So I'll run through the steps of getting Seam going on Gentoo.
To start off with, we'll need JDK (or JRE). Login as root,
emerge sun-jdk (in my case version 1.6.0.07) and logout. After that we need to get Tomcat.
Note: You can try to get Tomcat going through portage, but you'll end up pulling your hair out, because Seam uses the naming-factory-dbcp.jar, which is not included in the build for some bizarre reason.cd ~
mkdir applications
cd applications
wget http://apache.mirrors.hoobly.com/tomcat/tomcat-6/v6.0.18/bin/apache-tomcat-6.0.18.tar.gz
tar -xf apache-tomcat-6.0.18.tar.gz
Now let's set the environmental variables needed:
nano ~/.bashrc
and add these lines:
export JRE_HOME=/opt/sun-jdk-1.6.0.07
export TOMCAT_HOME=/home/yourname/applications/apache-tomcat-6.0.18
export CATALINA_HOME=$TOMCAT_HOME
export CATALINA_BASE=$TOMCAT_HOME
Note: You might want to emerge the tomcat-native package, since it will add the Apache Tomcat Native library. I'm not sure if Seam needs this, but I noticed Tomcat having a bit of a fit when it couldn't find it. The message in the $TOMCAT_HOME/logs/catalina.out was "INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path"One can also configure an admin user, but this is not necessarily required. Edit the tomcat-users.xml file like this:
nano $TOMCAT_HOME/conf/tomcat-users.xml
<tomcat-users>
<role rolename="manager">
<user username="root" password="irock" roles="manager">
</user>
One can now start Tomcat:
cd $TOMCAT_HOME/bin
./startup.sh
You should now be able to access Tomcat on
http://localhost:8080Tomcat will display
$TOMCAT_HOME/webapps/ROOT/index.htmlSo we can now follow Seam's Tomcat guide, which I had to modify a bit:
1. Go into the
jboss-seam/examples/jpa directory
2. Copy the lib
/hsqldb.jar into
$TOMCAT_HOME/lib3. Run
ant tomcat6 to build the application
4. Stop Tomcat
$TOMCAT_HOME/bin/shutdown.sh5. Remove previous any exiting deployments:
rm -r $TOMCAT_HOME/webapps/jboss-seam-jpa6. Copy war file:
cp dist-tomcat6/jboss-seam-jpa.war $TOMCAT_HOME/webapps7. Start Tomcat
$TOMCAT_HOME/bin/starup.sh8. Access the app at
http://localhost:8080/jboss-seam-jpaAnd Bob's you're uncle!