Skip to content

A small and efficient web server with 1K lines of C code

License

Notifications You must be signed in to change notification settings

sysprog21/sehttpd

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

seHTTPd

seHTTPd implements a small and efficient web server with 1K lines of C code. I/O multiplexing is achieved using epoll.

Features

  • Single-threaded, non-blocking I/O based on event-driven model
  • HTTP persistent connection (HTTP Keep-Alive)
  • A timer for executing the handler after having waited the specified time

High-level Design

+----------------------------------------------+
|                                              |
|  +-----------+   wait   +-----------------+  |  copy   +---------+
|  |           +---------->                 +------------>         |
|  | IO Device |    1     | Kernel's buffer |  |   2     | Process |
|  |           <----------+                 <------------+         |
|  +-----------+          +-----------------+  |         +---------+
|                                              |
+----------------------------------------------+

Build from Source

At the moment, seHTTPd supports Linux based systems with epoll system call. Building seHTTPd is straightforward.

$ make

Default server

./sehttpd

Specify the port

./sehttpd -p 8082 

Specify the port number with -p flag, by default the server accepts connections on port 8081.

Specify the web root

./sehttpd -w ./www

Specify the web root with -w flag, by default the web root is "./www".

License

seHTTPd is released under the MIT License. Use of this source code is governed by a MIT License that can be found in the LICENSE file.