Skip to content

Latest commit

 

History

History
52 lines (37 loc) · 1.58 KB

README.rst

File metadata and controls

52 lines (37 loc) · 1.58 KB

udprr

udprr is a simple udp load balancer using twisted.

Installation

Basic Python installation:

# on most linux distributions...
git clone git://github.com/kmcminn/udprr.git
cd udprr/
python setup.py install
cp contrib/udprr.init /etc/rc.d/init.d/udprr
cp contrib/udprr.logrotate /etc/logrotate.d/udprr
cp conf/udprr.conf /etc/udprr.conf

# edit udprr.conf for your setup, then...

chkconfig add udprr
chkconfig udprr on
service udprr start

Configuration

See the config file for basic options. On the command line:

$ udprr -h
Usage: udprr [options]

Options:
  -h, --help            show this help message and exit
  -l LOGGING_LEVEL, --logging-level=LOGGING_LEVEL
                        debug level default is warning
  -o LOG_FILE, --log-file=LOG_FILE
                        log to file instead of stdout
  -c CONFIG_FILE, --config-file=CONFIG_FILE
                        path to config file

About

Needed a lightweight load balancer and suprisingly couldn't find anything in github or elsewhere that 1) worked 2) wasn't old and 3) low quality. This was hacked up quickly and isnt very fancy, but works well and is stable.

Pull requests welcome.

Todo

Thread out a heartbeat that opens a raw socket parsing icmp port unreachables coming from downstream hosts and testing with icmp echoes and pushing the status across a queue back to the reactor to remove a host from round robin when its dead and to add it when its back.