Apache HTTP Server
The Apache HTTP Server, colloquially called Apache (/əˈpætʃi/ ə-PATCH-ee), is a free and open-source cross-platform web server software, released under the terms of Apache License 2.0. Apache is developed and maintained by an open community of developers under the auspices of the Apache Software Foundation.
Original author(s) | Robert McCool |
---|---|
Developer(s) | Apache Software Foundation |
Initial release | 1995[1] |
Stable release | 2.4.46 (August 7, 2020[2]) [±] |
Repository | |
Written in | C,[3] XML[4] |
Operating system | Unix-like, Microsoft Windows,[5] OpenVMS |
Type | Web server |
License | Apache License 2.0 |
Website | httpd |
The vast majority of Apache HTTP Server instances run on a Linux distribution,[6] but current versions also run on Microsoft Windows,[7] OpenVMS,[8] and a wide variety of Unix-like systems. Past versions also ran on NetWare, OS/2 and other operating systems,[9] including ports to mainframes.[10]
Originally based on the NCSA HTTPd server, development of Apache began in early 1995 after work on the NCSA code stalled. Apache played a key role in the initial growth of the World Wide Web,[11] quickly overtaking NCSA HTTPd as the dominant HTTP server. In 2009, it became the first web server software to serve more than 100 million websites.[12] As of January 2021, Netcraft estimated that Apache served 24.63% of the million busiest websites, while Nginx served 23.21% and Microsoft is in third place at 6.85% (for some of Netcraft's other stats Nginx is ahead of Apache),[13] while according to W3Techs, Apache is ranked first at 35.0% and Nginx second at 33.0% and Cloudflare Server third at 17.3%.[14]
Name
A number of explanations for the origin of the Apache name have been offered over the years.
From the inception of the Apache project in 1995 the official documentation stated:[15][16]
Apache is a cute name which stuck. It was based on some existing code and a series of software patches, a pun on “A PAtCHy” server.
In an April 2000 interview, Brian Behlendorf, one of the creators of Apache said:[17]
The name literally came out of the blue. I wish I could say that it was something fantastic, but it was out of the blue. I put it on a page and then a few months later when this project started, I pointed people to this page and said: "Hey, what do you think of that idea?" ... Someone said they liked the name and that it was a really good pun. And I was like, "A pun? What do you mean?" He said, "Well, we're building a server out of a bunch of software patches, right? So it's a patchy Web server." I went, "Oh, all right." ... When I thought of the name, no. It just sort of connotated: "Take no prisoners. Be kind of aggressive and kick some ass."
Since 2013 the Apache Foundation has explained the origin of the name as:[18]
The name 'Apache' was chosen from respect for the various Native American nations collectively referred to as Apache, well-known for their superior skills in warfare strategy and their inexhaustible endurance. It also makes a cute pun on "a patchy web server"—a server made from a series of patches—but this was not its origin. The group of developers who released this new software soon started to call themselves the "Apache Group".
When Apache is running under Unix, its process name is httpd
, which is short for "HTTP daemon".[19]
Feature overview
Apache supports a variety of features, many implemented as compiled modules which extend the core functionality. These can range from authentication schemes to supporting server-side programming languages such as Perl, Python, Tcl and PHP. Popular authentication modules include mod_access, mod_auth, mod_digest, and mod_auth_digest, the successor to mod_digest. A sample of other features include Secure Sockets Layer and Transport Layer Security support (mod_ssl), a proxy module (mod_proxy), a URL rewriting module (mod_rewrite), custom log files (mod_log_config), and filtering support (mod_include and mod_ext_filter).
Popular compression methods on Apache include the external extension module, mod_gzip, implemented to help with reduction of the size (weight) of web pages served over HTTP. ModSecurity is an open source intrusion detection and prevention engine for Web applications. Apache logs can be analyzed through a Web browser using free scripts, such as AWStats/W3Perl or Visitors.
Virtual hosting allows one Apache installation to serve many different websites. For example, one computer with one Apache installation could simultaneously serve example.com
, example.org
, test47.test-server.example.edu
, etc.
Apache features configurable error messages, DBMS-based authentication databases, content negotiation and supports several graphical user interfaces (GUIs).
It supports password authentication and digital certificate authentication. Because the source code is freely available, anyone can adapt the server for specific needs, and there is a large public library of Apache add-ons.[20]
A more detailed list of features is provided below:
- Loadable Dynamic Modules
- Multiple Request Processing modes (MPMs) including Event-based/Async, Threaded and Prefork.
- Highly scalable (easily handles more than 10,000 simultaneous connections)
- Handling of static files, index files, auto-indexing and content negotiation
- .htaccess per-directory configuration support[21]
- Reverse proxy with caching[22]
- Load balancing[23] with in-band health checks
- Multiple load balancing mechanisms
- Fault tolerance and Failover with automatic recovery
- WebSocket, FastCGI, SCGI, AJP and uWSGI support with caching
- Dynamic configuration[24]
- TLS/SSL with SNI and OCSP stapling support, via OpenSSL or wolfSSL.
- Name- and IP address-based virtual servers
- IPv6-compatible
- HTTP/2 support
- Fine-grained authentication and authorization access control[25]
- gzip compression and decompression
- URL rewriting[26]
- Headers[27] and content[28][29] rewriting
- Custom logging with rotation
- Concurrent connection limiting
- Request processing rate limiting
- Bandwidth throttling
- Server Side Includes[30]
- IP address-based geolocation
- User and Session tracking[31]
- WebDAV
- Embedded Perl, PHP and Lua scripting
- CGI support[32]
public_html
per-user web-pages[33]- Generic expression parser[34]
- Real-time status views[35]
- XML support[36]
- FTP support (by a separate module)[37]
Performance
Instead of implementing a single architecture, Apache provides a variety of MultiProcessing Modules (MPMs), which allow it to run in either a process-based mode, a hybrid (process and thread) mode, or an event-hybrid mode, in order to better match the demands of each particular infrastructure. Choice of MPM and configuration is therefore important. Where compromises in performance must be made, Apache is designed to reduce latency and increase throughput relative to simply handling more requests, thus ensuring consistent and reliable processing of requests within reasonable time-frames.
For delivering static pages, Apache 2.2 series was considered significantly slower than nginx and varnish.[38] To address this issue, the Apache developers created the Event MPM, which mixes the use of several processes and several threads per process in an asynchronous event-based loop.[39] This architecture as implemented in the Apache 2.4 series performs at least as well as event-based web servers, according to Jim Jagielski and other independent sources.[40][41][42] However, some independent but significantly outdated benchmarks show that it is still half as fast as nginx, e.g.[43]
Licensing
The Apache HTTP Server codebase was relicensed to the Apache 2.0 License (from the previous 1.1 license) in January 2004,[44] and Apache HTTP Server 1.3.31 and 2.0.49 were the first releases using the new license.[45]
The OpenBSD project did not like the change and continued the use of pre-2.0 Apache versions, effectively forking Apache 1.3.x for its purposes.[46][47][48] They initially replaced it with Nginx, and soon after made their own replacement, OpenBSD Httpd, based on the relayd project.[49][50][51][52]
Versions
Version 1.1: The Apache License 1.1 was approved by the ASF in 2000: The primary change from the 1.0 license is in the 'advertising clause' (section 3 of the 1.0 license); derived products are no longer required to include attribution in their advertising materials, only in their documentation.
Version 2.0: The ASF adopted the Apache License 2.0 in January 2004. The stated goals of the license included making the license easier for non-ASF projects to use, improving compatibility with GPL-based software, allowing the license to be included by reference instead of listed in every file, clarifying the license on contributions, and requiring a patent license on contributions that necessarily infringe a contributor's own patents.
Development
Version | Initial release | Latest release |
---|---|---|
1.3 | 1998-06-06[53] | 2010-02-03 (1.3.42)[54] |
2.0 | 2002-04-06[55] | 2013-07-10 (2.0.65)[56] |
2.2 | 2005-12-01[57] | 2017-07-11 (2.2.34)[58] |
2.4 | 2012-02-21[59] | 2020-08-07 (2.4.46)[60] |
Old version Latest version |
The Apache HTTP Server Project is a collaborative software development effort aimed at creating a robust, commercial-grade, feature-rich and freely available source code implementation of an HTTP (Web) server. The project is jointly managed by a group of volunteers located around the world, using the Internet and the Web to communicate, plan, and develop the server and its related documentation. This project is part of the Apache Software Foundation. In addition, hundreds of users have contributed ideas, code, and documentation to the project.[61][62][63]
Apache 2.4 dropped support for BeOS, TPF, A/UX, NeXT, and Tandem platforms.[9]
Security
Apache, like other server software, can be hacked and exploited. The main Apache attack tool is Slowloris, which exploits a bug in Apache software. It creates many sockets and keeps each of them alive and busy by sending several bytes (known as "keep-alive headers") to let the server know that the computer is still connected and not experiencing network problems. The Apache developers have addressed Slowloris with several modules to limit the damage caused; the Apache modules mod_limitipconn, mod_qos, mod_evasive, mod security, mod_noloris, and mod_antiloris have all been suggested as means of reducing the likelihood of a successful Slowloris attack.[64][65] Since Apache 2.2.15, Apache ships the module mod_reqtimeout as the official solution supported by the developers.[66]
See also
- .htaccess
- .htpasswd
- ApacheBench
- Comparison of web server software
- IBM HTTP Server
- LAMP (software bundle)
- List of Apache modules
- List of free and open-source software packages
- POSSE project
- suEXEC
- Apache Tomcat - another web server developed by the Apache Software Foundation
References
- "About the Apache HTTP Server Project". Apache Software Foundation. Archived from the original on 7 June 2008. Retrieved 2008-06-25.
- "Releases · apache/httpd · GitHub". GitHub. Retrieved 7 August 2020.
- "Archived copy". Archived from the original on 2016-03-02. Retrieved 2016-02-27.CS1 maint: archived copy as title (link)
- "Languages". Apache HTTP Server. Black Duck Software. Ohloh. Archived from the original on 7 April 2014. Retrieved 2 April 2014.
- "Compiling and Installing". httpd.apache.org. The Apache Software Foundation. Retrieved 9 May 2016.
- "OS/Linux Distributions using Apache". secure1.securityspace.com. Retrieved 2018-09-17.
- "Platform Specific Notes - Apache HTTP Server Version 2.4". httpd.apache.org. Retrieved 2019-01-21.
- "Secure Web Server". vmssoftware.com. Retrieved 2020-10-20.
- "Upgrading to 2.4 from 2.2".
Platform support has been removed for BeOS, TPF, and even older platforms such as A/UX, Next, and Tandem. These were believed to be broken anyway.
- "The Apache EBCDIC Port - Apache HTTP Server Version 2.4". httpd.apache.org. Retrieved 2019-08-16.
- Netcraft Market Share for Top Servers Across All Domains August 1995 - today (monthly updated)
- "February 2009 Web Server Survey". Netcraft. Archived from the original on 26 February 2009. Retrieved 2009-03-29.
- "December 2020 Web Server Survey". Netcraft News. Retrieved 2021-01-27.
- "Usage Statistics and Market Share of Web Servers, January 2021". w3techs.com. Retrieved 2021-01-27.
- "Information on the Apache HTTP Server Project". 1997-04-15. Archived from the original on April 15, 1997.
- "Apache Server Frequently Asked Questions". Archived from the original on 1997-01-06. Retrieved 15 January 2017.
- McMillan, Robert (15 April 2000). "Apache Power". Linux Magazine. Archived from the original on 28 January 2019.
- "Apache Foundation". www.apache.org. Retrieved 22 August 2018.
- "Apache Docs". httpd.apache.org. Retrieved 22 August 2018.
- "What is Apache Web Server? Webopedia". webopedia.com.
- "Apache HTTP Server Tutorial: .htaccess files". Apache.org.
- "mod_proxy". Apache.org.
- "mod_proxy_balancer". Apache.org.
- "Balancer Manager". Apache.org.
- "Authentication and Authorization". Apache.org.
- "mod_rewrite". Apache.org.
- "mod_headers". Apache.org.
- "mod_sed". Apache.org.
- "mod_substitute". Apache.org.
- "Apache httpd Tutorial: Introduction to Server Side Includes". Apache.org.
- "mod_usertrack". Apache.org.
- "Apache Tutorial: Dynamic Content with CGI". Apache.org.
- "Per-user web directories". Apache.org.
- "Expressions in Apache HTTP Server". Apache.org.
- "mod_status". Apache.org.
- "mod_xml2enc". Apache.org.
- "Apache Module: mod_ftp". Apache.org.
- "Serving static files: a comparison between Apache, Nginx, Varnish and G-WAN". Spoot!.
- "worker - Apache HTTP Server Version 2.2". apache.org.
- Apache httpd 2.4
- "Picking a Proxy Server".
- "Throughput evaluation of Apache 2.4.1".
- "Performance of Apache 2.4 with the event MPM compared to Nginx". eschrade.com.
- "Apache License, Version 2.0". The Apache Software Foundation. January 2004. Retrieved 2013-05-21.
- Burton, Richard Antony. "FYI: Apache HTTP Server 2.0.49 Released". Newsgroup: alt.apache.configuration. Retrieved 2018-02-16.
- de Raadt, Theo (18 February 2004). "The new apache license". openbsd-misc (Mailing list). Retrieved 2013-05-21.
- "Copyright Policy". OpenBSD. Retrieved 2013-05-12.
- "apache-httpd-openbsd-1.3.20140502p2 – OpenBSD improved and secured version of Apache 1.3". OpenBSD ports. Retrieved 2014-12-28.
- Marvin, Rob (25 March 2015). "Inside OpenBSD's new httpd Web server". SD Times. Retrieved 12 October 2019.
- "OpenBSD Upgrade Guide: 5.1 to 5.2". openbsd.org.
- jj, ed. (2014-03-14). "Heads Up: Apache Removed from Base". OpenBSD Journal.
- "OpenBSD Upgrade Guide: 5.5 to 5.6". openbsd.org.
- "Announcement: Apache 1.3.0 Released !". 1998-06-06. Retrieved 2015-01-06.
- "Apache HTTP Server 1.3.42 released (final release of 1.3.x)". apache.org.
- "Official Release: Apache 2.0.35 is now GA". 2002-04-06. Retrieved 2015-01-06.
- "[Announcement] Apache HTTP Server 2.0.65 Released". apache.org.
- "Apache HTTP Server 2.2.0 Released". 2005-12-01. Retrieved 2015-01-06.
- "[Announce] Apache HTTP Server 2.2.34 Released". apache.org.
- "[ANNOUNCEMENT] Apache HTTP Server 2.4.1 Released". 2012-02-21. Retrieved 2015-07-17.
- "Apache HTTP Server 2.4.46 Released". apache.org.
- Documentation Group. "About the Apache HTTP Server Project - The Apache HTTP Server Project". apache.org.
- The Apache HTTP Server Open Source Project on Ohloh. (n.d.). Ohloh, the open source network. Retrieved November 12, 2012
- "Chapter 4. The Apache HTTP Server". fedoraproject.org.
- "Slowloris HTTP DoS". Archived from the original on 26 April 2015. Retrieved 26 June 2009.CS1 maint: bot: original URL status unknown (link)
- "mod_noloris: defending against DoS". niq's soapbox. Retrieved 7 January 2012.
- "mod_reqtimeout". Apache.org. Retrieved 2013-07-03.