ASP.NET vs Ruby on Rails

A

Adam Sanderson

Since we're mentioning Java IDEs, Netbeans is pretty good too. It has
great XML/Html support. It's been getting a *lot* more polished
recently.

The funny thing is that since I started using ruby, I haven't *needed*
anything more than a text editor like Scite or TextMate. It's odd not
hitting ctrl-space every ten seconds ;)
.adam sanderson
 
J

John Lam

I saw a link to Christian's post on the Rails blog tonight so I
thought I'd chime in with a few additional points.

I've been building ASP.NET apps for a long time. I've taught probably
several thousand developers over the years how to write web
applications using ASP.NET. I used to manage DevelopMentor and
Wintellect's web curriculum back in the day.

So here it is: ASP.NET started out with a bad assumption and painted
themselves into a corner because of it. ScottGu & co are super-smart
guys, but when you start out with a bad assumption it's really hard to
overcome it. What was the bad assumption? That a forms-based "control"
model that was so successful in creating rich client apps a'la VB
would work on the web.

That model led to hacks like ViewState (ASP.NET's mechanism for
storing state on the client via a hidden HTML form field). Abuse of
ViewState prevents apps from working well in the *Internet* where
things like deep linking are commonplace.

That model keeps many, many developers and program managers employed
over at Developer Division building the tooling that is necessary to
keep a control-based model approachable to your typical web developer
in IT organizations around the world.

My team has built a really cool Rails application that we hope to
unveil to the world sometime soon. Total time to build: about 3
developer days. It's part of a much bigger project that is built on
top of a lot of ASMX / Web Services plumbing but I have to say that
the team enjoyed building the Rails code much more than the other
stuff :)

So while we're not all that big on Rails experience, we've really
liked what we've seen so far. In particular, the AJAX support really
makes for a compelling user experience. And the front-controller model
rocks so much harder than the page controller model in ASP.NET.

Our build / deployment infrastructure is now Ruby / Rake based.so
there's other Ruby code in the infrastructure as well. We've punted
NAnt out of our infrastructure and don't miss it one bit.

Now, a few things in defense of the .NET platform:

1) I18N and Unicode support. These are *huge* if they matter to you.
This support is baked into the platform at a very fundamental level
and is very well thought out.
2) Debugging support. This too is extremely well supported by the tool set.
3) SQL Express - if you want a free database there's nothing out there
that comes even close to this (although you'll have to pony up for a
Win2K3 Web Server Edition license so the overall package still costs
you money so it will play a bit of havoc with scale-out economics).
4) Performance. The CLR generates very fast executable code, and a lot
of attention has been focused on how to get apps to run fast on top of
IIS 6, which despite its configuration faults is a very secure and
very fast web server.

Notice that none of these points are directly tied to ASP.NET, and
that's intentional. I think that it's possible to write
high-performance web applications using ASP.NET, but it's so much
harder than it looks. With Rails it's a lot harder to write a bad
application because there's much more guidance than "throw a few
controls onto a page".

Cheers,
-John Lam
http://www.iunknown.com
 
J

John Lam

My question is this. Your brief experience with Rails and web services; =
how
was it. Any pointers for me?

Our experience with SOAP4R was not good. We wound up using ERb to
generate XML docs and sending them via HTTP POST to our ASP.NET web
service. SOAP4R barfed something awful on our ASMX-generated WSDL -
which does not use any bizarre XSD stuff nor estoeric WSDL features.

I had a similar experience when I first started experimenting with
SOAP4R with the Amazon Web Services - I wound up doing everything via
their REST interfaces instead.

Hopefully you'll have a better experience with SOAP4R but I couldn't
imagine a simpler "real" interface than the one that we expose -
essentially arrays of structs that contain strings (and only strings).

Cheers,
-John
http://www.iunknown.com
 
B

baalbek

John said:
3) SQL Express - if you want a free database there's nothing out there
that comes even close to this (although you'll have to pony up for a
Win2K3 Web Server Edition license so the overall package still costs
you money so it will play a bit of havoc with scale-out economics).

I beg to differ: Firebird ( http://firebird.sourceforge.net ) is the
King of Open Source, free databases.

A decade ago Firebird (then named Interbase) it was sold as a commercial
database, being used for quite demanding tasks, both on Windows and Unix.

Firebird is fast, extremely stable, with lots of features not available
even on commercial databases.

QZZ
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
474,176
Messages
2,570,948
Members
47,500
Latest member
ArianneJsb

Latest Threads

Top