10 Years of The Cathedral and The Bazaar
by Devanshu Mehta
In May 2007, that seminal work by “Eric S. Raymond”:http://www.catb.org/~esr turned ten years old. _The Cathedral and the Bazaar_ is a book about the simple notion that in software development _given enough eyeballs, all bugs are shallow_. Six years after Linux came on to the scene and 14 years after Richard Stallman gave birth to the GNU project, Eric Raymond put an intangible, untested concept in to words and has arguably had a phenomenal impact on software and geek culture.
When I wrote my “95 Theses of Geek Activism”:http://www.scienceaddiction.com/2006/07/23/95-theses-of-geek-activism/ last year, I put in CatB as a required reading as thesis #12 (the order meant nothing!). It could well have been #1, because it was the book that, for me, transformed the open source model from a touchy-feely philosophy to a practical, viable and achievable ideal for software development.
When Richard Stallman introduced the GNU project, it was a philosophy. You stuck with the GNU model because you believed in truth, liberty, freedom and justice. The BSD and other licenses were less philosophically rigid and have hence been taken advantage of by companies. Apple based their operating system OS X on BSD but were not obligated to share their improvements with the BSD community. They could take, but did not have to share. The GPL aimed at changing that- sharing was a many way street.
Linux brought the truly bazaar-style development in to the (geek) mainstream- where every user was a developer and the code was _released early and released often_. These facets of Linux development were part accidental, part consequences of the GPL and part Linus’ genius. Of course, Raymond was the first to test and formally describe the theories behind the success of Linux and how to apply them to future projects. Raymond tested the bazaar philosophy on his own _fetchmail_ project and the book tracks his success with it.
* *CatB as a Manifesto*: This book changed the geek language. Phrases such as the one above about eyeballs and bugs or the fundamental ideas about how to treat your beta testers are now treated as obvious. Indeed, even Yahoo and Google use the idea of treating their users as insider beta testers for many of their products.
* *CatB and O’Reilly*: _The Cathedral and the Bazaar_ was the first book published in print (by O’Reilly) with an open source document license. This allowed the book to be copied and modified as long as the resulting work had the same license- a precursor to “Creative Commons”:http://www.creativecommons.org licenses.
* *The Open Sourcing of Netscape*: The open sourcing of the Netscape browser and the start of the Mozilla project at the end of the browser wars in the late 90s is largely attributed to this book. At the time, CTO of Netscape, Eric Nahn told Raymond, “On behalf of everyone at Netscape, I want to thank you for helping us get to this point in the first place. Your thinking and writings were fundamental inspirations to our decision.”
Eric Raymond first presented _The Cathedral and the Bazaar_ at the “Linux Kongress on May 22nd, 1997”:http://www.linux-kongress.org/1997/ in WÃ¼rzburg, Germany. Ten years later, Linux is more powerful than ever, Ubuntu is ready for the desktop (says me) and the bazaar model is alive and thriving.
* Read “The Cathedral and the Bazaar”:http://www.catb.org/~esr/writings/cathedral-bazaar/cathedral-bazaar/
* About the “Netscape decision”:http://www.catb.org/~esr/writings/cathedral-bazaar/cathedral-bazaar/ar01s13.html
* Raymond’s ever-growing archive of “notes, comments, rebuttals and more”:http://www.catb.org/~esr/writings/cathedral-bazaar/ on CatB.
* Read Linus Torvalds’ fun, light and frothy autobiography about the heady young days of Linux “Just for Fun”:http://www.amazon.com/exec/obidos/ASIN/0066620732/galaxyfaraway
* And of course, there is the “The Circus Midget and the Fossilized Dinosaur Turd”:http://fringe.davesource.com/Fringe/Computers/Philosophy/Cathedral_Bazaar/Parody.html (don’t worry, it’s satire and it has a point)