The Architecture of Open Source Applications

3 min read Original article ↗

Architects look at thousands of buildings during their training, and study critiques of those buildings written by masters. In contrast, most software developers only ever get to know a handful of large programs well—usually programs they wrote themselves—and never study the great programs of history. As a result, they repeat one another's mistakes rather than building on one another's successes.

Our goal is to change that. In these two books, the authors of four dozen open source applications explain how their software is structured, and why. What are each program's major components? How do they interact? And what did their builders learn during their development? In answering these questions, the contributors to these books provide unique insights into how they think.

If you are a junior developer, and want to learn how your more experienced colleagues think, these books are the place to start. If you are an intermediate or senior developer, and want to see how your peers have solved hard design problems, these books can help you too.

AOSA Volume 1

Introduction Amy Brown and Greg Wilson
1. Asterisk Russell Bryant
2. Audacity James Crook
3. The Bourne-Again Shell Chet Ramey
4. Berkeley DB Margo Seltzer and Keith Bostic
5. CMake Bill Hoffman and Kenneth Martin
6. Eclipse Kim Moir
7. Graphite Chris Davis
8. The Hadoop Distributed File System Robert Chansler, Hairong Kuang, Sanjay Radia, Konstantin Shvachko, and Suresh Srinivas
9. Continuous Integration C. Titus Brown and Rosangela Canino-Koning
10. Jitsi Emil Ivov
11. LLVM Chris Lattner
12. Mercurial Dirkjan Ochtman
13. The NoSQL Ecosystem Adam Marcus
14. Python Packaging Tarek Ziadé
15. Riak and Erlang/OTP Francesco Cesarini, Andy Gross, and Justin Sheehy
16. Selenium WebDriver Simon Stewart
17. Sendmail Eric Allman
18. SnowFlock Roy Bryant and Andrés Lagar-Cavilla
19. SocialCalc Audrey Tang
20. Telepathy Danielle Madeley
21. Thousand Parsec Alan Laudicina and Aaron Mavrinac
22. Violet Cay Horstmann
23. VisTrails Juliana Freire, David Koop, Emanuele Santos, Carlos Scheidegger, Claudio Silva, and Huy T. Vo
24. VTK Berk Geveci and Will Schroeder
25. Battle For Wesnoth Richard Shimooka and David White
Bibliography

AOSA Volume 2

The Performance of Open Source Applications

500 Lines or Less

License and Royalties

This work is made available under the Creative Commons Attribution 3.0 Unported license. Please see the full description of the license for details. All royalties from sales of these books will be donated to Amnesty International.

Contributing

Dozens of volunteers worked hard to create this book, but there is still lots to do. You can help by reporting errors, by helping to translate the content into other languages and formats, or by describing the architecture of other open source projects. Please contact us the coordinators for various translations listed below, or mail us directly at gvwilson@third-bit.com if you would like to start a new translation or write a chapter yourself.