Hiawatha (web server)

From Wikipedia, the free encyclopedia
Hiawatha Webserver
Original author(s) Hugo Leisink
Developer(s) Hugo Leisink
Initial release 2002 (2002)
Stable release 9.2 / June 23, 2013 (2013-06-23)[1]
Written in C[2]
Operating system POSIX, Cross-platform
Platform Linux, Windows, Solaris, FreeBSD, OpenBSD, Unix-like, IBM AIX, HP-UX, QNX, Mac OS X, Haiku os[3]
Available in English
Type Web server
License GPLv2
Website www.hiawatha-webserver.org

Hiawatha is a web server available for multiple platforms. It has been developed by Hugo Leisink since 2002.[4]

History

Hiawatha started in January 2002 as a very small web server, suitable for servers with old hardware. It was written originally for Internet servers in student houses in Delft of South Holland, the Netherlands. Because the author was a computer science student with special interest in IT security, all sorts of experimental security features were included. This resulted in a web server with many interesting security features which have proven useful. The author has said "I know for a long time that vulnerabilities [exist in other web servers] . [One thing] that bothers me: the runtime of a CGI. A CGI process [under other web servers] can run forever. A single CGI script can DoS a webserver. A system administrator is needed to kill the script. And what about a client [or hacker] that keeps on guessing passwords for HTTP authentication? These kind of issues inspired me to create Hiawatha, with settings for maximum request sending time, maximum CGI run time, client banning, etc. Features that, in my opinion, every daemon should have."[citation needed]

The January 2009 edition of Linux Magazine contained an article about the Hiawatha web server.

Important releases
  • 1.0: September 2002. A basic but functional web server.
  • 2.0: March 2004. Use of multithreading instead of forking.
  • 3.0: September 2004. SSL support.
  • 4.0: December 2005. A CGI-wrapper[5] for improved security was included.
  • 5.0: October 2006. FastCGI support for improved CGI speed.
  • 5.2: November 2006. First-time integration to the FreeBSD Ports system at version 5.2 in December 2006,[6] to the OpenBSD ports tree at version 5.7 in March 2007.[7]
  • 5.12: August 2007. URL rewriting support.
  • 6.0: October 2007. IPv6 support.
  • 6.6: April 2008. XSLT support.
  • 6.10 : October 2008. Prevent cross-site request forgery added.
  • 7.0: February 2010. Remote monitoring support.
  • 8.0: January 2012. Autoconf replaced with CMake, OpenSSL replaced with PolarSSL.
  • 9.0: March 2013. Clients handled via thread pool instead of creating threads on the fly.

Features

Hiawatha web server implements all important functions of a modern web server, such as:

Hiawatha has many security features that no other web server has, like preventing SQL-injection, cross-site scripting (XSS), Cross-site request forgery (CSRF) prevention, denial-of-service protection, control external image linking, banning of potential hackers and limiting the runtime of CGI applications.[8] The author worked on RFC3546 support, but "the OpenSSL documentation [on this subject] is just extremely poor"[citation needed] so progress was difficult. Although, RFC3546 support has been included since v8.6 version which is developed with PolarSSLv1.2 .

Performance

Although security is the main focus, Hiawatha is also doing quite well in terms of speed and performance. According to a performance test carried out by an independent researcher (SaltwaterC), Hiawatha beats others for static content.[9] Hiawatha supports load-balanced FastCGI and had its own PHP-FastCGI utility, although the latter has been deprecated and replaced with the PHP project's FastCGI Process Manager (PHP-FPM).[10] This makes it fast and scalable for handling dynamic content.

See also

  • Comparison of web servers
  • Comparison of lightweight web servers

References

External links

This article is issued from Wikipedia. The text is available under the Creative Commons Attribution/Share Alike; additional terms may apply for the media files.