Using Ruby in a Corporate Environment

S

Steve Molitor

---------- Forwarded message ----------
From: Curt Hibbs <[email protected]>
Date: Apr 26, 2007 12:41 PM
Subject: Re: [stlruby] St. Louis Companies Using Ruby
To: (e-mail address removed)
Cc: "St. Louis Ruby Users Group" <[email protected]>
Curt,

Thanks for some really helpful pointers. Love the Spolsky essay. I'm
sending it to my boss and our project managers.

The two hurdles to using Ruby more at my company are convincing my
boss, and convincing the developers. My boss is worried about the
usual stuff: staffing, training, scalability, etc. You've helped me
with the staffing and training issues, and we can do some benchmarking
to test scalability. (Rails should scale just fine for our needs.)

Surprisingly, while most of the developers are either excited or at
least open to the idea, there are one or two developers who are
definitely opposed to Ruby. (OK, one to be precise: but there could
be others who haven't spoken out.) The objections are that Ruby is
not used or accepted enough in the corporate world, and that learning
Ruby won't help them make more money or more marketable (in the St.
Louis corporate world). If corporations start explicitly looking for
Ruby developers they'll learn it, but not until then.

I'm not quite sure how to answer this one. While I do think that
something is going to succeed Java, I can't predict the future. I
can't truthfully say with assurance that Ruby will be the next big
thing in the corporate world. It *might* be, but it might not.
Personally I'm not concerned about what the next big thing might be; I
want a language that makes me and my fellow developers happy and more
productive. That's good for us and good for the business, I figure.
I have trouble understanding the narrow, strictly mercenary and
corporate focused point of view. Any ideas on convincing these folks?

Thanks again.

Steve Molitor



My company is thinking of moving to Ruby, and Ruby on Rails, in a fairly big way -- maybe to the point of making it the preferred language and framework for new applications. We've been dabbling with Ruby and Rails in one decent sized app and a few tiny apps. My boss is concerned about the issues in transitioning a mostly Java shop to Ruby -- training, integrating with the existing Java apps, etc. He would feel a lot better if he could talk to folks from another St. Louis company who have made that transition. Does anyone work in a corporate environment that uses Ruby extensively, or know someone who does? And if so, can we talk to you?

Thanks!

Steve Molitor

First, let me just briefly mention that we are moving mailing list to
Google Groups (which I cc'd on this response). So, if you could join
our Google group and direct future messages there, it would be a big
help.

I can't answer your primary question directly (other STL-RUG members
may have more direct information for you). But I can give you some
information.

Training is available both locally and nationally. The Pragmatic
Programmer's Rails Studio (Dave Thomas and Mike Clark) is probably the
premier nationally given Rails training. Locally, Object Computing Inc
teaches both Ruby and Rails classes through Washington University's
CAIT program (our monthly meetings are held at OCI's offices). And two
of our members, Jeff Barczewski and Mike Sullivan, have formed a
training company (Inspired Horizons) that specializes in Rails
training.

If you need to integrate Ruby with existing Java apps, then you
probably want to look closely at JRuby (http://www.headius.com/
jrubywiki/index.php/Main_Page ).

Finally, don't be intimidated by a lack of seasoned Ruby/Rails
programmers, just concentrate on hiring good programmers (they know
how to pick up new languages and technologies quickly). Joel Spolsky
put it very well in his essay "Sorting Resumes" (the whole thing is
worth reading):


http://www.joelonsoftware.com/articles/SortingResumes.html
If I needed to hire someone to do Ruby development, someone with
extensive Smalltalk and Python experience who had never even heard of
Ruby would be a lot more likely to be successful than someone who read
a book about Ruby once. For someone who is basically a good software
developer, learning another programming language is just not going to
be a big deal. In two weeks they'll be pretty productive.

I hope that helps... good luck and keep us posted on your progress!

Curt
 
P

Philip Hallstrom

Surprisingly, while most of the developers are either excited or at
least open to the idea, there are one or two developers who are
definitely opposed to Ruby. (OK, one to be precise: but there could
be others who haven't spoken out.) The objections are that Ruby is
not used or accepted enough in the corporate world, and that learning
Ruby won't help them make more money or more marketable (in the St.
Louis corporate world). If corporations start explicitly looking for
Ruby developers they'll learn it, but not until then.

I'm not quite sure how to answer this one. While I do think that
something is going to succeed Java, I can't predict the future. I
can't truthfully say with assurance that Ruby will be the next big
thing in the corporate world. It *might* be, but it might not.
Personally I'm not concerned about what the next big thing might be; I
want a language that makes me and my fellow developers happy and more
productive. That's good for us and good for the business, I figure.
I have trouble understanding the narrow, strictly mercenary and
corporate focused point of view. Any ideas on convincing these folks?

I can't see how learning a language even if it's not one actively being
recruited for is a bad thing... I'd much rather hire someone who had used
many languages than just the currently hyped one.

Seems the more languages you know the easier it is to learn others
quickly as well

<sarcasm hidden_meaning=+1>
As for their wish to learn it only once corporations want it, that's fine
with me, because when that time comes I'll not only have years of
experience with Ruby, but I'll also have projects that have been *in the
field* for years as well to back up my resume.
</sarcasm>

my 2 cents, -philip
 
G

Greg Donald

Seems the more languages you know the easier it is to learn others
quickly as well

I agree. But it's also much easier to get confused. Today I couldn't
figure out why in the world my calls to trim() would not work in
Python. After a while I finally realized I meant to use strip() not
trim(). I guess working in Python by day and PHP at night is messing
with my head a bit.
As for their wish to learn it only once corporations want it, that's fine
with me, because when that time comes I'll not only have years of
experience with Ruby, but I'll also have projects that have been *in the
field* for years as well to back up my resume.

w0rd.
 
P

Philip Hallstrom

I agree. But it's also much easier to get confused. Today I couldn't
figure out why in the world my calls to trim() would not work in
Python. After a while I finally realized I meant to use strip() not
trim(). I guess working in Python by day and PHP at night is messing
with my head a bit.

True, but that's the same with switching anything... I usually drive an
automatic truck... but one day took my wife's stick sedan... I did fine,
but I had to remember a couple of times that there was a clutch :)

And the bottom line is that if I hired you do to PHP full time you'd be
de-confused in a day or two. How long would it take if you'd never even
seen PHP till start day?

Personally though I think there's something about PHP that is confusing...
I tend to leave off semicolons these days and wonder why exactly it's
complaining about a syntax error :)

-philip
 
P

Phillip Gawlowski

Steve said:
---------- Forwarded message ----------
From: Curt Hibbs <[email protected]>
not used or accepted enough in the corporate world, and that learning
Ruby won't help them make more money or more marketable (in the St.
Louis corporate world). If corporations start explicitly looking for
Ruby developers they'll learn it, but not until then.

I'm channeling Catbert, Evil Director of Human Resources here:
Start looking for developers skilled in Ruby.
I'm not quite sure how to answer this one. While I do think that
something is going to succeed Java, I can't predict the future. I
can't truthfully say with assurance that Ruby will be the next big
thing in the corporate world. It *might* be, but it might not.
Personally I'm not concerned about what the next big thing might be; I
want a language that makes me and my fellow developers happy and more
productive. That's good for us and good for the business, I figure.
I have trouble understanding the narrow, strictly mercenary and
corporate focused point of view. Any ideas on convincing these folks?

Again the evil approach: add it to the job description. Either they
learn it (their employer *requires* it), or they should start looking
for new jobs.

If their only reason for learning a language is "corporations look for
it", they can't be that good as programmers, as they only learn the
usage of a language, but not its philosophy. Which, methinks, is key to
becoming a Great Programmer, and not be a code monkey or mercenary..

P.S.: I am not advocating to make those programmers redundant outright,
but recommending them to maintenance tasks, as has been suggested, is a
good solution, IMHO.

--
Phillip "CynicalRyan" Gawlowski
http://cynicalryan.110mb.com/
http://clothred.rubyforge.org

Rule of Open-Source Programming #9:

Give me refactoring or give me death!
 
R

Robert Dober

---------- Forwarded message ----------
<snip>
http://www.joelonsoftware.com/articles/SortingResumes.html
If I needed to hire someone to do Ruby development, someone with
extensive Smalltalk and Python experience who had never even heard of
Ruby would be a lot more likely to be successful than someone who read
a book about Ruby once. For someone who is basically a good software
developer, learning another programming language is just not going to
be a big deal. In two weeks they'll be pretty productive.

For sure, they will write beautiful Smalltalk and Python programs in Ruby.
That does not necessarily mean that your decision is bad, but in order
to push the team towards Ruby I'd at least hire one or two charismatic
Ruby evangelists, and yes I am available ;)

Cheers
Robert
 
A

Alexey Verkhovsky

The two hurdles to using Ruby more at my company are convincing my
boss, and convincing the developers. My boss is worried about the
usual stuff: staffing, training, scalability, etc. You've helped me
with the staffing and training issues, and we can do some benchmarking
to test scalability. (Rails should scale just fine for our needs.)

Depends on what your needs are, but with modern hardware you can
usually go a long way before you hit scalability ceiling, far enough
for most web sites and business apps.
The objections are that Ruby is
not used or accepted enough in the corporate world, and that learning
Ruby won't help them make more money or more marketable (in the St.
Louis corporate world).

I don't know about St.Louis, but personally I've been getting job
offers roughly once a month since a year and half ago. Even though
there isn't much Ruby in the city where I live, and I'm not even
soliciting those job opportunities (I mean, I'm not looking for an
indie gig for myself; ThoughtWorks is always on a lookout for Ruby
work).

There is a market for Ruby, and it is growing fast. Having Ruby on
your CV now, if nothing else, marks you as a forward-looking
technologist in the eyes of knowledgeable employers who watch industry
trends.
If corporations start explicitly looking for
Ruby developers they'll learn it, but not until then.

Like someone else said earlier in the thread, people with this
attitude to new technologies really belong in the legacy/maintenance
world (and will do just fine there).

Should your IT strategy be driven by an effect it would have on
someone's employability by *some other company*, anyway?
something is going to succeed Java,

Java is very well entrenched, nothing is going to completely displace
it any time soon. Ruby partially displacing Java to a significant
degree (and perhaps completely displacing PHP) is a trend that we are
already observing in ThoughtWorks customer base. We mostly work with
large corporations.
Personally I'm not concerned about what the next big thing might be;

In ThoughtWorks, we are obviously betting on Ruby, but we are a
relatively large software consultancy, and it's not the only possible
Next Big Thing we are betting on. Making this sort of bets is part of
our business.

Corporate IT departments, however, do not need to speculate about such
things. The right question for you, guys, is: "(1) is Ruby big enough
and (2) will it become obsolete within the lifespan of our
application?". The answer to that question, from where I sit, looks
like a certain "yes to (1), no to (2)" since about a year and half
ago. Assuming that your planned application lifespan is less than 20
years, that is.

By the way, my personal crystal ball also says that Java will be
obsolete a good few years before Ruby. But that's just speculation
again.
I have trouble understanding the narrow, strictly mercenary and
corporate focused point of view. Any ideas on convincing these folks?

Convincing late adopters to adopt is an uphill battle probably not
worth fighting. Instead, convince decision-makers that mercenary view
is irrelevant to company interests, and do not include those people in
the Ruby project team, at least not in the beginning.

Corporate-focused view, on the other hand, is entirely appropriate. In
many business IT scenarios, you really need fast time to market above
everything else. If you are like that, Ruby is presently one of your
best available choices.
 

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

No members online now.

Forum statistics

Threads
473,969
Messages
2,570,161
Members
46,708
Latest member
SherleneF1

Latest Threads

Top