What is Ratchet? ================ The purpose of the ratchet library is to provide a generic socket control mechanism for large numbers of sockets without using threads or losing the ease of synchronous socket programming. Implementations of standard Berkeley sockets are provided, as well as rudimentary support for ZeroMQ sockets, provided versions greater than or equal to 2.1.0 are installed. The polling mechanism is written on top of libevent (http://monkey.org/~provos/libevent/). The ratchet library provides and manages a blend of libevent event loops and Lua coroutines to provide the effect of synchronous socket programming. Each call to a blocking socket (or DNS or ZeroMQ) method actually yields execution until the action is ready to be taken. Ratchet coroutines may also wait for each other. Any application protocol (text-based or binary) can be implemented. Currently, example HTTP and SMTP client and server implementations are provided, see docs for details. The project itself is built using autotools for portability, though it depends on several GNU/Linux features. The project provides a suite of post-build tests which double as sample usages, executed with "make check". Build Information ================= Lua 5.2+ is required to build, as this is a Lua library. Other than that, it should work on most modern GNU/Linux systems with kernel 2.6+ and glibc2. If your distribution or custom install added a suffixes to differentiate Lua versions, you can use the configure option: --with-lua-suffix=ARG Gives suffix for Lua binary and library files. Many distributions do not yet include Lua 5.2 in package management. To avoid blowing away an existing Lua 5.1 install, you might want to install Lua 5.2 somewhere unique. Let's say you installed in /opt/lua-5.2: PATH="/opt/lua-5.2/bin:$PATH" \ CFLAGS="$CFLAGS -I/opt/lua-5.2/include" \ LDFLAGS="$LDFLAGS -I/opt/lua-5.2/lib" \ ./configure If the paths to C and Lua module installation directories are not available from pkg-config, they may need to be manually specified with: --with-lua-cpath=CPATH Install Lua C modules to CPATH --with-lua-lpath=LPATH Install Lua modules to LPATH There are two different ways to use this library: from C or from Lua. By default, both options are made available. If you don't need to use the library from the Lua interpreter, you can choose to disable that with the configure option: --disable-module Disable the Lua module. Similarly, if your Lua installation is custom, or the path to install Lua C modules is not available in pkg-config, you can define a custom installation path for the Lua module with a configure option: --enable-module=PATH Install the Lua module ratchet.so to PATH. If you do not need the developement libraries and headers installed, you can choose to disable them with the configure option: --disable-devel Disable developement headers and libraries. By default, ratchet attempts to build with ZeroMQ (2.1.0+ is required). If you do not need access to ZeroMQ sockets or do not meet the version requirement, you can disable that portion of the library with a configure option: --disable-zeromq Disable usage of ZeroMQ libraries. By default, ratchet uses dns.c to provide enhanced DNS querying. If you do not need access to DNS queries whatsoever, you can disable that portion of the build with the configure option below. Note, however, that currently there is no built-in method to build the data required for BSD sockets without this feature. --disable-dns Disable usage of dns.c libraries. To encrypt socket channels, ratchet can tie in to the OpenSSL suite. This is important, for example, to implement HTTPS or the STARTTLS SMTP command. If included in the build, the OpenSSL global state will be initialized every time a program using the ratchet library is started, regardless of if/when encryption is used (see `SSL_library_init()` and `SSL_load_error_strings()`). OpenSSL will not be included in the build if the following configure option is given: --disable-openssl Disable usage of OpenSSL libraries. For Linux users (see version requirements below), there is access to the timerfd (man page `timerfd_create()`) routines for intelligent time keeping and time-based triggers. If the requirements can't be met, this feature can be disabled with a configure option: --disable-timerfd Disabe usage of timerfd calls. If, for any reason, you do not need access to BSD sockets (for example you only need ZeroMQ, timers, or thread management), you can disable inclusion of these features with another configure option: --disable-socket Disable usage of BSD sockets. Example protocol implementations, installed to the Lua module path, can be disabled with the following configure options: --disable-http Do not install HTTP protocol implementation. --disable-smtp Do not install SMTP protocol implementation. To increase the size of the buffer used when the size of a piece of data is unknown, you can also use the following configure variable. Currently, it only controls the size of the buffer used in `recv()` system calls. BUFSIZ The size of the intermediate buffers used when building large Lua strings. All other configure options are standard from GNU autotools. Dependencies ============ * Lua 5.2+ (http://www.lua.org) * libevent 2+ (http://libevent.org/) * Without --disable-zeromq: ZeroMQ 2.1.0+ (http://www.zeromq.org) * Without --disable-timerfd: Linux kernel 2.6.25+, Glibc 2.8+ * Without --disable-openssl: OpenSSL (http://www.openssl.org/)