MIDRANGE dot COM Mailing List Archive



Home » WEB400 » May 2006

Re: CGI vs JSP...



fixed

Good points Scott. I just want to add my two cents in :-)

>If multiple tiers, back end databases, etc are important to you, .NET
should also be given serious consideration. 

I want to challenge this because I just don't understand (literally) the
benefit to going with .NET (which inherently means you have Windows and
IIS). Let me clarify that a little more by first saying that I don't
disagree that a language like C#.NET is powerful, but it's the other baggage
that comes with it (i.e. Windows and IIS). I just don't think Microsoft is
"Enterprise Server" ready. Yes they have good desktop software and email
software and, and, and, but let's remember how recently they have entered
into the enterprise server market and how long IBM has existed in the space.
Will they catch up to IBM fast? You bet! But they have a good five years
before they do so (very unscientific projection :-). 

The reason .NET gets such great adoption is because it is extremely easy to
program in.  Microsoft is a master at integration within themselves. Great!
You can get your programming done in 3/4 the time as a Java developer. The
thing that doesn't appear until later is the scaling problems and lack of
options in the event you aren't getting what you need. 

I think the thing that set me off the most was the "serious" portion of the
consideration :-)  I think .NET would be great for small businesses, but not
the right choice for enterprise or potential enterprise applications.

>Another Pro of using Java that you didn't list is that there's lots and
lots of functionality available.

Agree 100%.  It is almost to a fault how many choices one has with Java.
Just look at all of the different frameworks out there and the different
components you can have within each framework. It is truly amazing.

Shane, if you have Java knowledge I would head down that path. The web tier
event driven frameworks are getting better all the time. I don't think I
would go with raw JSP/Servlets but actually look into some "pre-packaged"
abilities like JSF (Java Server Faces) or Tapestry or Spring (haven't used).

Aaron Bartell


-----Original Message-----
From: web400-bounces@xxxxxxxxxxxx [mailto:web400-bounces@xxxxxxxxxxxx] On
Behalf Of web400@xxxxxxxxxxxxxxxx
Sent: Friday, May 12, 2006 6:55 PM
To: Web Enabling the AS400 / iSeries
Subject: Re: [WEB400] CGI vs JSP...


> CGI - Pros:
> You probably already know RPG.
> Easy to start with.

If you change "CGI" to "CGIDEV2" then I'll agree with that!  Getting started
with CGI when you aren't using CGIDEV2 (or a comparable toolkit) is not
easier.


> CGI - Cons:
> Doesn't always scale well.
> Locks you into using iSeries as your webserver and as your back-end.
> HTTP server and web application must be in same tier.
> Tough to hire people that know anything about RPG-CGI.

These are more the cons of RPG than they are of CGI.  Most of your
restrictions come from the fact that RPG really only runs on iSeries
systems.

It doesn't really lock you into using the iSeries as both the web server 
and back-end...   The web server does need to be iSeries to run RPG, but 
an RPG program can talk to other computers to get the data.  You could have
a back-end computer running DB2 and query it from RPG.  Or RPG could run a
web service on another computer, or communicate with another computer using
data queues or sockets.

It's just less common because there's such wider support for Java in the
industry.  JDBC drivers are easy to find, so communicating with databases
over a network from Java is much more common.

Like I said, your restrictions are really because of RPG, not CGI.

The major cons of CGI itself are:

a) It requires starting up a separate process outside of the web server.

On most platforms this is very expensive.  It'd be like submitting a new job
for every RPG program you run, waiting for it to finish before doing the
next step.  The overhead of submitting the job is significant.

However, on the iSeries it isn't such a big problem because the CGI jobs
remain active and are re-used.  You don't have to start new ones over and
over.  Plus, iSeries programs can remain in memory with their files open and
variables intact so that they can be called again very quickly.  In RPG we
think of this as ending with *INLR = *OFF, but it's available via activation
groups in other ILE languages as well.  Since no other platform has this
functionality, and iSeries is such a tiny niche of the market, this is still
considered a huge blemish on CGI in general.

b) CGI programs traditionally have the HTML hard-coded in them, making them
hard to update.

This isn't a problem with CGIDEV2 or similar toolkits.  Again, most
platforms dont' have these toolkits for CGI.  So the ease of encoding the
HTML in a JSP or PHP script is extremely attractive.  On the iSeries, we can
do something very similar with CGIDEV2 or similar, so the difference isn't
so big.

c) There's all of the work of decoding the variables from web forms, storing
them somehow where it's easy to utilize them, etc.

Again, CGIDEV2 and similar tools do that for you, but on other platforms the
tools that do this aren't very good, or do less of the work for you. 
For a long time, the standard on Unix systems was to code CGI in Perl using
a module called CGI.pl because it helped decode these variables.  It didn't
help with the HTML part of it, so when PHP had both the functionality of
CGI.pm and the ease of coding the HTML, it blew Perl out of the water.

Unfortunately, most people who have programmed in CGI aren't iSeries people
and haven't ever seen a toolkit like CGIDEV2.  To them, CGI is old and
awkward and slow because of the above reasons.

> JSP Pros:
> Easy to find people who know it.
> Can run web app tier on just about any platform.
> Can connect to multiple back-end databases.
> Can separate HTTP server tier from web app tier.
> Lots of open-source resources.

I actually haven't had much problem findint people familiar with CGIDEV2
programming.  But, there are more Java developers than iSeries *users*, so
it's definitely easier to find Java developers familiar with web
programming.  And drastically more open source resources, since 95% of the
iSeries community still doesn't understand open source.

However, there's even more PHP open source out there.  PHP is also extremely
widely used, at least as widely used as Java.

If multiple tiers, back end databases, etc are important to you, .NET should
also be given serious consideration.  There seem to be more .NET developers
out there than Java, as well, and aside from the open source aspect, it
matches all of the other pros of Java.

Another Pro of using Java that you didn't list is that there's lots and lots
of functionality available.  By that, I mean routines that assist you with
writing web applications.  Far more tools than CGIDEV2 provides. 
(Though, again, .NET and PHP have most of the same tools as Java)

> JSP Cons:
> You probably don't know it.
> Can be tough to get started if you don't have an experienced Java person.

Also, for a small shop, performance can be a big problem with Java. 
That's my biggest gripe about it.
--
This is the Web Enabling the AS400 / iSeries (WEB400) mailing list To post a
message email: WEB400@xxxxxxxxxxxx To subscribe, unsubscribe, or change list
options,
visit: http://lists.midrange.com/mailman/listinfo/web400
or email: WEB400-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives at
http://archive.midrange.com/web400.






Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2014 by MIDRANGE dot COM and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available here. If you have questions about this, please contact