Software:Yaws (web server)

From HandWiki
Short description: HTTP web server software


Yaws
Developer(s)Claes Wikström
Written inErlang
Operating systemCross-platform
TypeWeb server
LicenseBSD-3-Clause
Website{{{1}}}
The LYME and LYCE software bundles are based on Erlang and comprise Yaws. They are composed entirely of free and open-source software

Yaws (Yet another web server) is a web server written in Erlang by Claes (klacke) Wikström. Yaws can be embedded into other Erlang-based applications or run as a regular standalone web server.[1]

Overview

Because Yaws uses Erlang's lightweight threading system, it performs well under high concurrency. A load test conducted in 2002 comparing Yaws and Apache found that with the hardware tested, Apache failed at 4,000 concurrent connections, while Yaws continued functioning with over 80,000 concurrent connections.[2]

The load test concludes,

"The problem with Apache is not related to the Apache code per se but is due to the manner in which the underlying operating system (Linux) implements concurrency. We believe that any system implemented using operating system threads and processes would exhibit similar performance. Erlang does not make use of the underlying OS's threads and processes for managing its own process pool and thus does not suffer from these limitations".[2]

and in the underlined part above (formatting added), expresses the opinion that the founding technologies make the difference in scalability.

See also

References

  1. Vinoski, Steve (July–August 2011). "The Functional Web - Yaws: Yet Another Web Server". IEEE Internet Computing. IEEE Computer Society. http://steve.vinoski.net/pdf/IC-Yaws.pdf. 
  2. 2.0 2.1 Ghodsi, Ali. "Apache vs. Yaws". https://www.sics.se/~joe/apachevsyaws.html. 

External links

  • ErlyWeb – MVC-pattern web framework for Yaws
  • Website Monitoring Software - Integrated Status Data Platform
  • Erlang Web – MVC-pattern web framework Yaws and Inets Erlang/OTP application
  • Nitrogen – An event-driven Web 2.0 framework for Erlang that runs on Yaws, Mochiweb, and Inets