I recently was working on an application that was Servlet based in Tomcat. That was pretty good. It was nice to be able to roam around the Java language and libraries and do stuff with threads and such.
Before this most of my Java experience was EJB. I don't really like EJB. It seems annoying a lot of the time with its rules and restrictions. And it's so verbose and so much overhead getting things deployed and callable. We've had some success using XDoclet to auto-generate some of the verbiage, but it's still big. We're not even using entity beans, thankfully; that would be just so much more overheads.
We have to be quick to get things done on aggressive schedules and be able to modify existing systems for new requirements. Sometimes with J2EE it seems like we're a courier trying to deliver packages in the downtown business district using a tractor trailer. The big rig is scalable; you can load all kinds of heavy freight on it, but in the downtown during the daytime it is so bulky that it has trouble navigating the traffic, changing direction or parking. For the traffic congested downtown you'd be better with one of the UPS brown vans, which carry a big enough load, but can move around better in thick traffic and tight parking and can change direction easily based on how business unfolds that day.
Now if you're moving say 40 brand new large sofas from a warehouse in Montreal to a furniture store in Sydney then the tractor trailer is the best vehicle to use. You can fit them all in one load, and the rig manages the long highway miles easily.
Looking at it that way, it makes me sometimes get down a bit on J2EE. But thinking about it more, I think my gripe is more with EJB than with the full J2EE. After all I know I like the Servlets stuff. EJB just seems to suck up the joy of programming at times.
I know I'm not the only one who isn't excited about EJB. When people write entire books about J2EE without EJB then there are many others too who want to use J2EE but are turned off by EJB. Still with J2EE, especially EJB the specs are just eye glazing. Even a book like the 21 days that tries hard to be accessible and reader friendly is painful to read when they necessarily delve into the J2EE specs and rules. I wish the concepts and terminology could be somehow simplified.
I always thought that EJB was a necessary evil to obtain scalability. Turns out that's not so. walmart.com was built using just Apache and Tomcat servlets. Apparently no need for EJB to achieve performance, security, etc. I find that very interesting.
So if we don't need it to get scalability then maybe we'd be better off without EJB. Just use servlet - which I've found well thought through and agreeable to work with - plus a much more lightweight framework, or maybe no real extra framework. That idea appeals to me. I'll get to work with Tomcat and servlet for a bit longer on this project, I'm not real excited about going back to EJB.
No comments:
Post a Comment