/h2o

HTTP server / library implementation with support for HTTP/1, HTTP/2, websocket

Primary LanguageCMIT LicenseMIT

H2O - an optimized HTTP server / library implementation

H2O is an optimized HTTP server implementation that can be used either as a standalone server or a library.

Supported Protocols

  • HTTP/1.0 (http and https)
  • HTTP/1.1 (http and https)
  • Websocket (RFC6455, both ws and wss)
  • HTTP/2.0 (draft 14, via Upgrade, NPN, ALPN)

Dependencies

  • OpenSSL (mandatory)
  • libyaml (optional; required when building the server)
  • libuv 1.0.0 (optional; required when using h2o as a library)
  • wslay (optional; required if you need support for websocket)

Benchmark

Written from the ground up, H2O outperforms nginx by more than 2x. The table below is a comparison of request-per-seconds taken using ab -c 500 -n 100000 -k on Ubuntu 14.04 running on VMWare Fusion.

Server \ size of content 6 bytes 4,096 bytes
nginx/1.7.4 (conf) 35,822 32,885
H2O @ 6085457 76,690 67,866

Building and Running the Server

Run the commands below to build and run the H2O server. The last command will read the configuration from examples/h2o.conf and start listening on port 8080. Try accessing http://127.0.0.1:8080/.

$ git submodule update --init --recursive
$ cmake .
$ make h2o
$ ./h2o -c examples/h2o.conf

Building the Library

$ git submodule update --init --recursive
$ cmake .
$ make libh2o

The library is designed to work together with the upcoming libuv version 1.0.0. Examples can be found within the examples/ directory.