• Home
  • About the ramblings…

Ramblings of a Short Man

~ Written by Thai Bui, read by… um… millions

Ramblings of a Short Man

Monthly Archives: October 2011

All big technology companies should be structured like Amazon

13 Thursday Oct 2011

Posted by Thai Bui in Technology

≈ 2 Comments

I read Steve Yegge’s rant on Amazon and Google and, like everyone else in the tech world, thought it was fascinating. But the really interesting thing is Steve’s description of how the different groups at Amazon work together through services. It’s the most succinct and argument I’ve seen for diving fully head first into a complete SOA model.  And not just technically, but fully as a business.

The key to Jeff Bezos’ mandate was that the services would be designed from the ground up to be externalized. With that key requirement, you’ve suddenly gone from a simple API to an API with full documentation, full security, full SLAs, full Dev and QA environments, full versioning, etc.

I’ve only worked in one reasonably complex organization, and that was Intuit for three years after the acquisition of Homestead. While I was there, I saw the technical group at Intuit struggle with the problem of scaling their development community, and I think it was heading down a fairly common road: standardization on technologies and libraries (at every level of the stack feasible) to increase buying power, increase code reuse, and decrease training overhead.  But the result was also fairly common and predictable: central core groups struggling to enforce mandates while client groups try to work around the system.  There was (and probably still is) a move philosophically toward SOA, but even then, use of that SOA was often done when organizationally required as opposed to technically prudent.

In my opinion, Steve Yegge’s description of Amazon’s model is how any company of any significant technical complexity should work (including Intuit), and the benefits are profound.

  1. With full documentation, security, SLAs, Dev and QA environments, versioning, etc., you remove much of the bureaucracy (i.e., meetings) that surround creating technology together. If you implement an SOA in name only, like just an API (which I’ve seen a lot because it’s considered just a technical concern as opposed to a full business concern), then you’ve just replaced an architectural design meeting with an API design meeting and not made any progress toward more loosely coupled technical teams.
  2. In defining your service interfaces at a business level (including SLAs, etc.), client tech groups will be able to compare the internal service with external services.  For example, the company should encourage client tech groups to compare between AWS and corporate IT, and the client tech group should pick the best service provider for their needs.
  3. The ultimate result of #2 harsh but true: if the client tech groups predominantly prefer AWS, the company should figure out how to satisfy their clients better or get out of the business of corporate IT. That is, you’ll find out very soon which of your technical projects have value and which don’t.  And I bet most of them will end up going away.
Think of it this way: in our startup, of course, we’re really trying to build and own as little technology as possible and almost any service you can think of is available out there right now. And the reason one service often wins out over another is a “good enough” feature set and great developer tools/documentation. And if a company can’t compete with that internally, they really just shouldn’t do it.
Advertisement

Subscribe

  • Entries (RSS)
  • Comments (RSS)

Archives

  • April 2016
  • September 2014
  • December 2013
  • October 2013
  • July 2013
  • May 2013
  • November 2012
  • January 2012
  • October 2011
  • September 2011
  • August 2011
  • May 2010
  • March 2010
  • January 2010
  • April 2008
  • March 2008
  • January 2008
  • November 2007
  • October 2007
  • September 2007
  • August 2007
  • July 2007
  • June 2007
  • May 2007
  • April 2007
  • March 2007
  • February 2007
  • January 2007
  • December 2006
  • November 2006
  • September 2006
  • July 2006
  • June 2006
  • March 2006
  • February 2006
  • January 2006

Categories

  • AJAX
  • Analytics
  • Blogging
  • Food
  • Gadgets
  • Homestead
  • Intuit
  • Mobile
  • Patents
  • Recruiting
  • SEO
  • Social Networking
  • Software Development
  • Spam
  • Startups
  • Technology
  • TV/Movies
  • Uncategorized
  • Web 2.0
  • Web 2.0 Expo

Meta

  • Register
  • Log in

Create a free website or blog at WordPress.com.

Privacy & Cookies: This site uses cookies. By continuing to use this website, you agree to their use.
To find out more, including how to control cookies, see here: Cookie Policy
  • Follow Following
    • Ramblings of a Short Man
    • Already have a WordPress.com account? Log in now.
    • Ramblings of a Short Man
    • Customize
    • Follow Following
    • Sign up
    • Log in
    • Report this content
    • View site in Reader
    • Manage subscriptions
    • Collapse this bar