Open Source Software Development: the Apache Server", Intl

Open Source Software Development: the Apache Server", Intl

Course "Softwareprozesse" Open Source Software (OSS) Development Lutz Prechelt Freie Universität Berlin, Institut für Informatik Part 1: Part 2: • Definition • Project types, • Process characteristics, leadership and decision-making strengths • The OSS career • Economical incentives • OSS license types • OSS tools • Innovation management in OSS Lutz Prechelt, [email protected] 1 / 92 Learning objectives • Understand the definition of Free/Open Source SW • Understand typical process characteristics: • participants, process, productivity, quality • leadership and decision-making, participant career • economical incentives for participation • tools used • Understand the various OSS licenses • Understand the notion of innovation management and how it applies to OSS Lutz Prechelt, [email protected] 2 / 92 Which software is open source? • OSS dominant: • OSS relevant: Infrastructure software Vertical application software • Operating systems • https://www.getapp.com • Android, *Linux, *BSD, • CRM systems FreeRTOS, etc. etc. • ERP systems (usage statistics) • iDempiere, OFBiz, • Programming language Openbravo, Odoo implementations: • Finance/accounting • C/C++, Java, JavaScript, PHP, Python, R, Ruby, etc. • Health information systems • DBMS: • HR systems • MySQL/MariaDB, PostgreSQL, SQlite, etc. most noSQL DBMSs • Web servers: • Apache httpd, nginx • Web browsers: • Chrome, Firefox etc. seeLutz Precheltalso, [email protected] of-berlin.de: CMS, browsers, languages, … 3 / 92 Contrasts: proprietary, shared source, closed source • Most company software is proprietary ("eigen", "geschützt"): The copyright holder reserves the right to use the software • either to himself (custom SW) • this is the default case in most country's copyright laws • or to people who accept restrictions regarding the use of the SW and usually pay a license fee (commercial SW products) • Usually (but not always) proprietary SW is closed-source • meaning even the allowed users only get to see a binary version • If not, this is sometimes called "shared source" • e.g. from Microsoft (main purpose: create trust) Lutz Prechelt, [email protected] 4 / 92 Definition "Free Software" Richard Stallman, Free Software Foundation (FSF): http://www.gnu.org/philosophy/free-sw.html • The freedom to run the program, for any purpose (freedom 0) • The freedom to study how the program works, and adapt it to your needs (freedom 1). • This requires access to the source code. • The freedom to redistribute copies so you can help your neighbor (freedom 2). • The freedom to modify the program, and release your improvements to the public, so that the whole community benefits (freedom 3). On Richard Stallman, see • http://www.faifzilla.org/ and http://www.catb.org/~esr/writings/rms-bio.html Lutz Prechelt, [email protected] 5 / 92 Definition "Open Source Software" • Stallman calls such software "Free Software" • he promotes it actively since 1985 • http://www.fsf.org/ • Today, the more common term is "Open Source Software" • abbreviated OSS • This move was initiated in 1998 Eric Raymond by Eric Raymond: • because the term free "makes a lot of corporate types nervous" • Adacemically, sometimes also termed "Free/Libre and Open Source Software (F/LOSS)" • abbreviated FLOSS or shortened to FOSS or F/OSS • Free SW now has two "home organizations": FSF and OSI, the Open Source Initiative • http://opensource.org/ Lutz Prechelt, [email protected] 6 / 92 The OSS turning point • [Fitzgerald06] The introduction of the "OSS" term marks a dramatic mainstreaming of F/LOSS development and use: • many more OSS developers • in particular many more paid OSS developers • more pragmatic, less ideological attitude • many new business models • proliferation of licenses • enormous uptake by users • enormous uptake by developers as component users • appearance of vertical OSS applications • some larger-scale OSS projects • more explicit, more structured development processes • Fitzgerald calls this "OSS 2.0" Lutz Prechelt, [email protected] 7 / 92 Warning: No binary thinking! Lutz Prechelt, [email protected] 8 / 92 Pragmatic OSS case study: Apache httpd • History: • The NCSA (at University of Illinois) developed the web's first widely used web server software, httpd, in the early 1990s • When the primary author left NCSA, several httpd users started sending around bug fixes ("patches") and improvements by email • When this process became too tiresome, it evolved into a proper project for developing what would be Apache httpd • Status today: • By-and-large the world's leading web server for over 20 years • Highly stable and function-rich Web Server • Plug-in architecture with about 90 default extensions ("modules") • and over 400 more released by people outside the Apache project • Core team size about 60 people, democratic process • Founding project of the Apache SW foundation • http://www.apache.org now >350 different projects (2017-11) Lutz Prechelt, [email protected] 9 / 92 Case study: Apache httpd Market share (Netcraft web server survey) Lutz Prechelt, [email protected] 10 / 92 Case study: Apache httpd Process characteristics • Audris Mockus, Roy Fielding, James Herbsleb: "A Case Study of Open Source Software Development: The Apache Server", Intl. Conf. on Software Engineering, ACM press, 2000 • Analyzes the apache project during 1996 to 1998/99 • 50,000 emails sent over mailing list during this timeframe • essentially all communication goes over the list • phone and personal email are uncommon in many OSS projects • A voting system with quorum is used for decision-making • Common code base is managed in a CVS versioning system • Change requests are managed in a problem reporting database (BUGDB) Lutz Prechelt, [email protected] 11 / 92 Case study: Apache httpd Process characteristics (2) • Members of the Apache Group (AG) have write access to CVS • A person can become a member after about 6 months of contributing to the project • Current members vote on acceptance of new members • There were 8/12/12/25 members in 1995/1996/1998/2000 • 66 members in 2012-11 • "Core developers" are the active AG members plus a few soon-to-become-members contributors (typically 2-3) • People tend to work on those parts of the product they are most familiar with • Often equivalent to implicit code ownership: The opinion of a creator of code area X has greater weight in discussions about X • Therefore, new developers tend to either develop new features or take over code of a developer that is leaving Lutz Prechelt, [email protected] 12 / 92 Case study: Apache httpd Process characteristics (3) The size of the Apache development community: • 182 people contributed to 695 changes related to problem reports (PRs) • 249 people contributed to 6092 other changes or extensions • Overall, almost 400 people contributed code • 3060 people submitted the 3975 problem reports • 458 of them submitted the 591 that lead to one or more changes Magnitude hypothesis for successful OSS projects: • if core developers := 1 then developers=10, bugreporters=100 How widely was work distributed among people? • The top 15 developers (out of 388!) contributed 83% of the change transactions, 88% of the added lines, and 91% of the deleted lines • (see graph on next slide) • i.e. by far most people make few and small changes only Lutz Prechelt, [email protected] 13 / 92 Case study: Apache httpd Process characteristics (4) • Distribution of number and size of contributions over people • most pronounced for new code: there are 4 developers per 100 non-PR changes, but 26 per 100 Apache PR changes • PR: problem report Commercial projects A, B Lutz Prechelt, [email protected] 14 / 92 Case study: Apache httpd Process characteristics (5) • MRs: number of changes (modific. request) • Delta: number of files changed Lutz Prechelt, [email protected] 15 / 92 Case study: Apache httpd Process characteristics (6) No system-testing Avoids favoring is common in OSS bloated code • Note that Apache is much higher-used than A, C, D, E • so the numbers will represent a higher fraction of all defects Lutz Prechelt, [email protected] 16 / 92 OSS process: What's typical? [Johnsson01], • Participation is tiered [CroWeiHow12], • OSS "career": onion model Driving forces: (user, bug reporter, 1-time contributor, developer, • Prototyping is closed core-developer) • Most projects start as Leadership is trust-based closed-source or by an • individual (meritocracy) • User-driven requirements, • Planning is informal developers are often users • less so in large projects with heave company • Less so for vertical involvement applications Organization view: • Collaboration is decentralized • not much hierarchical communication Lutz Prechelt, [email protected] 17 / 92 OSS process: What's typical? (2) Development style: • Tool support is ubiquitous • Requirements elicitation: • Issue tracking, version • From semi-formal to management, automated implicit (by reacting to user build and test requests) • Information space is shared • Iterative process • Central repositories for • Maintenance is basically source code, bug fixing plus arbitrary re- documentation, invention issue database, releases etc. • Communication is asynchronous, mostly email • Release: • Wide variety, from "release • Architectures are designed early, release often" to for modularity fixed intervals with explicit • To minimize coupling and stabilization phases hence communication effort • see the

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    92 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us