/haproxytool

A tool to interact with HAProxy via stats socket

Primary LanguagePythonApache License 2.0Apache-2.0

haproxytool

A tool to manage HAProxy via stats socket.

It uses haproxyadmin Python library to interact with HAProxy and run all commands. One of the main feature is that can work with HAProxy in multi-process mode (nbproc > 1)

Examples

Usage

The command line interface tries to be friendly and compatible with the rest of the tools available in the Linux land. The docopt Python module is used to build the CLI interface.

Here is the basic syntax to start with:

% haproxytool
Usage: haproxytool [-v | -h] <command> [<args>...]

% haproxytool -h
A tool to manage HAProxy via the stats socket.

Usage: haproxytool [-v | -h] <command> [<args>...]

Options:
-h, --help                show this screen.
-v, --version             show version.

Available haproxytool commands are:
    haproxy   HAProxy operations
    frontend  Frontend operations
    backend   Backend operations
    server    Server operations
    dump      Dumps all informations
    map       Manage MAPs
    acl       Manage ACLs

See 'haproxytool help <command>' for more information on a specific command.

Keep reading for more details about each command.

Commands for HAProxy

  • Usage
% haproxytool haproxy --help
Manage haproxy

Usage:
    haproxytool haproxy [-D DIR | -F SOCKET] (-a | -A | -C | -e | -i | -M |
                                            -o | -r | -u | -U | -V | -R | -p)
    haproxytool haproxy [-D DIR | -F SOCKET] -m METRIC
    haproxytool haproxy [-D DIR | -F SOCKET] -w OPTION VALUE
    haproxytool haproxy [-D DIR | -F SOCKET] -c COMMAND

Arguments:
    DIR     Directory path with socket files
    OPTION  Option name to set a VALUE
    VALUE   Value to set
    METRIC  Name of a metric, use '-M' to get metric names

Options:
    -a, --all                   clear all statistics counters
    -A, --clear                 clear max values of statistics counters
    -c, --command               send a command to HAProxy
    -C, --maxconn               show configured maximum connection limit
    -e, --errors                show last know request and response errors
    -F SOCKET, --file SOCKET    socket file
    -i, --info                  show haproxy stats
    -m, --metric                show value of a METRIC
    -M, --show-metrics          show all metrics
    -o, --options               show value of options that can be changed with
                                '-w' option
    -p, --pids                  show PIDs of HAProxy processes
    -r, --requests              show total cumulative number of requests
                                processed by all processes
    -u, --uptime-secs           show uptime of HAProxy process in seconds
    -U, --uptime                show uptime of HAProxy process
    -V, --hap-version           show version of HAProxy
    -R, --release-date          show release date
    -w, --write                 set VALUE for an OPTION
    -D DIR, --socket-dir=DIR    directory with HAProxy socket files
                                [default: /var/lib/haproxy]

Commands for frontends

  • Usage
% haproxytool frontend --help
Manage frontends

Usage:
    haproxytool frontend [-D DIR -F SOCKET] (-c | -r | -s | -o | -e | -p | -i)
                         [NAME...]
    haproxytool frontend [-D DIR -F SOCKET] -w OPTION VALUE [NAME...]
    haproxytool frontend [-D DIR -F SOCKET] [-f ] (-d | -t) [NAME...]
    haproxytool frontend [-D DIR -F SOCKET] (-l | -M)
    haproxytool frontend [-D DIR -F SOCKET] -m METRIC [NAME...]

Arguments:
    DIR     Directory path with socket files
    SOCKET  Socket file
    VALUE   Value to set
    OPTION  Setting name
    METRIC  Name of a metric, use '-M' to get metric names

Options:
    -c, --showmaxconn         show max sessions
    -d, --disable             disable frontend
    -e, --enable              enable frontend
    -f, --force               force an operation
    -F SOCKET, --file SOCKET  socket file
    -h, --help                show this screen
    -i, --iid                 show proxy ID number
    -l, --show                show all frontends
    -m, --metric              show value of a metric
    -M, --show-metrics        show all metrics
    -o, --options             show value of options that can be changed with
                            '-w' option
    -p, --process             show process number
    -r, --requests            show requests
    -s, --status              show status
    -t, --shutdown            shutdown frontend
    -w, --write               change a frontend option
    -D DIR, --socket-dir=DIR  directory with HAProxy socket files
                            [default: /var/lib/haproxy]
  • Show status of frontend(s)
% haproxytool frontend -s
frontend_proc1 OPEN
frontend2_proc34 OPEN
haproxy OPEN
frontend1_proc34 OPEN
frontend_proc2 OPEN

% haproxytool frontend -s frontend2_proc34
frontend2_proc34 OPEN
  • Show requests
% haproxytool frontend -r frontend2_proc34
frontend2_proc34 10
  • Show in which HAProxy process a frontend is used
% haproxytool frontend -p frontend2_proc34
frontend2_proc34 [4, 3]
  • Show option(s) that can be changed
NOTE:Currently, HAProxy allows only to change the maximum connections option for the frontends.
% haproxytool frontend -o frontend_proc1
frontend_proc1 maxconn=1000000
  • Change an option
% haproxytool frontend -w maxconn 100000 frontend_proc1
frontend_proc1 set maxconn to 100000

% haproxytool frontend -o frontend_proc1
frontend_proc1 maxconn=100000
  • Changing an option for a frontend assigned to multiple HAProxy process
% haproxytool frontend -o frontend1_proc34
frontend1_proc34 maxconn=2000000

% haproxytool frontend -w maxconn 40000 frontend1_proc34
frontend1_proc34 set maxconn to 40000

% haproxytool frontend -o frontend1_proc34
frontend1_proc34 maxconn=80000

% haproxytool frontend -p frontend1_proc34
frontend1_proc34 [4, 3]
NOTE:It is not supported to change a option only to one of the HAProxy process
NOTE:The return value of the option is the sum of the values across all HAProxy processes

Commands for backends

  • Usage
% haproxytool backend --help
Manage backends

Usage:
    haproxytool backend [-D DIR | -F SOCKET] (-S | -r | -p | -s | -i) [NAME...]
    haproxytool backend [-D DIR | -F SOCKET] (-l | -M)
    haproxytool backend [-D DIR | -F SOCKET] -m METRIC [NAME...]

Arguments:
    DIR     Directory path with socket files
    SOCKET  Socket file
    METRIC  Name of a metric, use '-M' to get metric names

Options:
    -F SOCKET, --file SOCKET  socket file
    -h, --help                show this screen
    -i, --iid                 show proxy ID number
    -l, --show                show all backends
    -m, --metric              show value of a metric
    -M, --show-metrics        show all metrics
    -p, --process             show process number
    -r, --requests            show requests
    -s, --status              show status
    -S, --servers             show servers
    -D DIR, --socket-dir=DIR  directory with HAProxy socket files
                              [default: /var/lib/haproxy]

Commands for servers

  • Usage
% haproxytool server --help
Manage servers

Usage:
    haproxytool server [-D DIR | -F SOCKET] (-A | -r | -s | -e | -R | -p | -W |
                    -i | -c | -C | -S | -X) [--backend=<name>...] [NAME...]
    haproxytool server [-D DIR | -F SOCKET] -w VALUE [--backend=<name>...]
                    [NAME...]
    haproxytool server [-D DIR | -F SOCKET] -a VALUE [--backend=<name>...] NAME
    haproxytool server [-D DIR | -F SOCKET] -x VALUE [--backend=<name>...] NAME
    haproxytool server [-D DIR | -F SOCKET] [-f ] (-d | -t | -n)
                    [--backend=<name>...] [NAME...]
    haproxytool server [-D DIR | -F SOCKET] (-l | -M)
    haproxytool server [-D DIR | -F SOCKET] -m METRIC [--backend=<name>...]
                    [NAME...]


Arguments:
    DIR     Directory path with socket files
    SOCKET  Socket file
    VALUE   Value to set
    METRIC  Name of a metric, use '-M' to get metric names

Options:
    -a, --address             set server's address
    -A, --show-address        show server's address
    -c, --show-check-code     show check code
    -C, --show-check-status   show check status
    -d, --disable             disable server
    -e, --enable              enable server
    -f, --force               force an operation
    -F SOCKET, --file SOCKET  socket file
    -h, --help                show this screen
    -i, --sid                 show server ID
    -l, --show                show all servers
    -m, --metric              show value of a metric
    -M, --show-metrics        show all metrics
    -n, --drain               drain server
    -p, --process             show process number
    -r, --requests            show requests
    -R, --ready               set server in normal mode
    -s, --status              show status
    -S, --show-last-status    show last check status
    -t, --maintenance         set server in maintenance mode
    -w, --weight              change weight for server
    -W, --get-weight          show weight of server
    -x --port                 set servers's port
    -X, --show-port           show servers's port
    -D DIR, --socket-dir=DIR  directory with HAProxy socket files
                              [default: /var/lib/haproxy]
  • List all servers
% haproxytool server -l
# backendname servername
backend1_proc34                bck1_proc34_srv1
backend1_proc34                bck1_proc34_srv2
backend1_proc34                bck_all_srv1
backend_proc2                  bck_proc2_srv4_proc2
backend_proc2                  bck_proc2_srv3_proc2
backend_proc2                  bck_proc2_srv2_proc2
backend_proc2                  bck_proc2_srv1_proc2
backend_proc1                  member1_proc1
backend_proc1                  member2_proc1
backend_proc1                  bck_all_srv1
backend2_proc34                bck2_proc34_srv1
backend2_proc34                bck_all_srv1
backend2_proc34                bck2_proc34_srv2
  • Show status of servers per backend
% haproxytool server -s --backend=backend_proc1
# backendname servername
backend_proc1                  bck_all_srv1                               DOWN
backend_proc1                  member1_proc1                              no check
backend_proc1                  member2_proc1                              no check


% haproxytool server -s --backend=backend_proc1 --backend=backend2_proc34
# backendname servername
backend_proc1                  member1_proc1                              no check
backend_proc1                  bck_all_srv1                               DOWN
backend_proc1                  member2_proc1                              no check
backend2_proc34                bck2_proc34_srv2                           UP
backend2_proc34                bck2_proc34_srv1                           no check
backend2_proc34                bck_all_srv1                               no check
  • Show weight of servers across all backends and per backend
% haproxytool server -W bck_all_srv1
# backendname servername
backend1_proc34                bck_all_srv1                               1
backend2_proc34                bck_all_srv1                               1
backend_proc1                  bck_all_srv1                               100

% haproxytool server -W bck_all_srv1 --backend=backend_proc1 --backend=backend2_proc34
# backendname servername
backend_proc1                  bck_all_srv1                               100
backend2_proc34                bck_all_srv1                               1
  • Set weight on servers across all backends and per backend
% haproxytool server -w 10 bck_all_srv1
bck_all_srv1 backend set weight to 10 in backend2_proc34 backend
bck_all_srv1 backend set weight to 10 in backend1_proc34 backend
bck_all_srv1 backend set weight to 10 in backend_proc1 backend

% haproxytool server -w 50 bck_all_srv1 --backend=backend_proc1 --backend=backend2_proc34
bck_all_srv1 backend set weight to 50 in backend_proc1 backend
bck_all_srv1 backend set weight to 50 in backend2_proc34 backend
  • Show requests
% haproxytool server -r bck_all_srv1
# backendname servername
backend_proc1                  bck_all_srv1                               0
backend2_proc34                bck_all_srv1                               2
backend1_proc34                bck_all_srv1                               10
  • Show/change address of a server
% haproxytool server -D /run/haproxy --show-port srv1
backend_dynamic                srv1                                       7777
% haproxytool server -D /run/haproxy --port 8888 srv1
set port for srv1 server to 8888 in backend_dynamic backend

% haproxytool server -D /run/haproxy --show-address srv1
backend_dynamic                srv1                                        127.0.0.9
% haproxytool server -D /run/haproxy --address 127.0.0.10 srv1
set address for srv1 server to 127.0.0.10 in backend_dynamic backend
  • List metric names available from the statistics
% haproxytool server -M
qcur
qmax
scur
smax
stot
bin
bout
dresp
econ
eresp
wretr
wredis
weight
act
bck
chkfail
chkdown
lastchg
downtime
qlimit
throttle
lbtot
rate
rate_max
check_duration
hrsp_1xx
hrsp_2xx
hrsp_3xx
hrsp_4xx
hrsp_5xx
hrsp_other
cli_abrt
srv_abrt
lastsess
qtime
ctime
rtime
ttime

Please consult CSV format of HAProxy for their description.

  • Show the value of a specific metric
% haproxytool server -m bin bck_all_srv1
# backendname servername
backend1_proc34                bck_all_srv1                               760
backend2_proc34                bck_all_srv1                               152
backend_proc1                  bck_all_srv1                               0
  • Show in which HAProxy process a server is used
% haproxytool server -p bck_all_srv1
# backendname servername
backend2_proc34                bck_all_srv1                               [4, 3]
backend_proc1                  bck_all_srv1                               [1]
backend1_proc34                bck_all_srv1                               [4, 3]
  • Enable/disable a server
% haproxytool server -d bck_all_srv1
Are you sure we want to disable 3 servers y/n?: y
bck_all_srv1 disabled in backend1_proc34 backend
bck_all_srv1 disabled in backend_proc1 backend
bck_all_srv1 disabled in backend2_proc34 backend
NOTE:When more than one server are about to be disabled, user is prompted to confirm the action. Use -f to skip this confirmation.
% haproxytool server -s bck_all_srv1
# backendname servername
backend_proc1                  bck_all_srv1                               MAINT
backend2_proc34                bck_all_srv1                               MAINT
backend1_proc34                bck_all_srv1                               MAINT

% haproxytool server -e bck_all_srv1
bck_all_srv1 enabled in backend2_proc34 backend
bck_all_srv1 enabled in backend1_proc34 backend
bck_all_srv1 enabled in backend_proc1 backend

% haproxytool server -s bck_all_srv1
# backendname servername
backend1_proc34                bck_all_srv1                               UP
backend2_proc34                bck_all_srv1                               no check
backend_proc1                  bck_all_srv1                               DOWN

Dump command

  • Usage
% haproxytool dump --help
Dump a collection of information about frontends, backends and servers

Usage:
    haproxytool dump [-D DIR | -F SOCKET] [-fbsh]

Arguments:
    SOCKET  Socket file

Options:
    -f, --frontends           show frontends
    -F SOCKET, --file SOCKET  socket file
    -b, --backends            show backends
    -s, --servers             show servers
    -D DIR, --socket-dir=DIR  directory with HAProxy socket files
                              [default: /var/lib/haproxy]

Map command

  • Usage
% haproxytool map --help
Manage MAPs

Usage:
    haproxytool map [-D DIR | -F SOCKET] -l
    haproxytool map [-D DIR | -F SOCKET] (-s | -c ) MAPID
    haproxytool map [-D DIR | -F SOCKET] -g MAPID KEY
    haproxytool map [-D DIR | -F SOCKET] (-S | -A) MAPID KEY VALUE
    haproxytool map [-D DIR | -F SOCKET] -d MAPID KEY


Arguments:
    DIR     Directory path with socket files
    MAPID   ID of the map or file returned by show map
    KEY     ID of key
    SOCKET  Socket file
    VALUE   Value to set

Options:
    -A, --add                 add a <KEY> entry into the map <MAPID>
    -F SOCKET, --file SOCKET  socket file
    -h, --help                show this screen
    -s, --show                show map
    -g, --get                 lookup the value of a key in the map
    -c, --clear               clear all entries for a map
    -l, --list                list all map ids
    -S, --set                 set a new value for a key in a map
    -d, --delete              delete all the map entries from the map <MAPID>
                              corresponding to the key <KEY>
    -D DIR, --socket-dir=DIR  directory with HAProxy socket files
                              [default: /var/lib/haproxy]
  • List all MAPIDs
% haproxytool map -l
# id (file) description
4 (/etc/haproxy/v-m1-bk) pattern loaded from file '/etc/haproxy/v-m1-bk'
used by map at file '/etc/haproxy/haproxy.cfg' line 87
  • Show the content of a map
% haproxytool map -s 4
0xb743f0 0 www.foo.com-0
0xb74460 1 www.foo.com-1
  • Add a key to a map
% haproxytool map -A 4 3 www.goo.com
key was added successfully

% haproxytool map -s 4
0xb743f0 0 www.foo.com-0
0xb74460 1 www.foo.com-1
0x28f0f50 3 www.goo.com
  • Delete an entry from a map
% haproxytool map -d 4 3
key was deleted successfully

% haproxytool map -s 4
0xb743f0 0 www.foo.com-0
0xb74460 1 www.foo.com-1
  • Set a value for a key in a map
% haproxytool map -S 4 1 bar.com
value was set successfully

% haproxytool map -s 4
0xb743f0 0 www.foo.com-0
0xb74460 1 bar.com
  • Clear all entries of a map
% haproxytool map -c 4
all entries of map were cleared successfully

% haproxytool map -s 4

%
NOTE:Currently, HAProxy doesn't allow to create new MAPs via the stats socket.

ACL command

  • Usage
% haproxytool acl --help
Manage ACLs

Usage:
    haproxytool acl [-D DIR | -F SOCKET] -l
    haproxytool acl [-D DIR | -F SOCKET] (-c | -s) ACLID
    haproxytool acl [-D DIR | -F SOCKET] (-A | -g ) ACLID VALUE
    haproxytool acl [-D DIR | -F SOCKET] -d ACLID KEY


Arguments:
    DIR     Directory path with socket files
    ACLID   ID of the acl or file returned by show acl
    SOCKET  Socket file
    VALUE   Value to set
    KEY     Key ID of ACL value/pattern

Options:
    -h, --help                show this screen
    -A, --add                 add a <KEY> entry into the acl <ACLID>
    -F SOCKET, --file SOCKET  socket file
    -s, --show                show acl
    -g, --get                 lookup the value of a key in the acl
    -c, --clear               clear all entries for a acl
    -l, --list                list all acl ids
    -d, --delete              delete all the acl entries from the acl <ACLID>
                              corresponding to the key <KEY>
    -D DIR, --socket-dir=DIR  directory with HAProxy socket files
                              [default: /var/lib/haproxy]
  • List all ACLIDs
% haproxytool acl -D /run/haproxy -l
# id (file) description
0 (/etc/haproxy/wl_stats) pattern loaded from file '/etc/haproxy/wl_stats' used by acl at file '/etc/haproxy/haproxy.cfg' line 55
1 () acl 'src' file '/etc/haproxy/haproxy.cfg' line 55
2 (/etc/haproxy/bl_frontend) pattern loaded from file '/etc/haproxy/bl_frontend' used by acl at file '/etc/haproxy/haproxy.cfg' line 85
3 () acl 'src' file '/etc/haproxy/haproxy.cfg' line 85
5 () acl 'ssl_fc' file '/etc/haproxy/haproxy.cfg' line 88
6 () acl 'req.cook' file '/etc/haproxy/haproxy.cfg' line 101
7 () acl 'req.cook' file '/etc/haproxy/haproxy.cfg' line 102
8 () acl 'req.cook' file '/etc/haproxy/haproxy.cfg' line 103
  • Show the content of a acl
% haproxytool acl -D /run/haproxy -s 2
0x2115c90 11.155.183.41
0x3e92f80 10.10.10.10
  • Add an entry in a acl
% haproxytool acl -D /run/haproxy --add 2 12.12.12.0
value was added successfully

% haproxytool acl -D /run/haproxy -s 2
0x2115c90 11.155.183.41
0x3e92f80 10.10.10.10
0x21341e0 12.12.12.0
  • Delete an entry from acl
% haproxytool acl -D /run/haproxy --delete 2 12.12.12.0
key was deleted successfully

% haproxytool acl -D /run/haproxy -s 2
0x2115c90 11.155.183.41
0x3e92f80 10.10.10.10
  • Lookup entries in acl for debugging purposes
% haproxytool acl -D /run/haproxy -g 2 11.155.183.41
type=ip, case=sensitive, match=yes, idx=tree, pattern="11.155.183.41"

%haproxytool acl -D /run/haproxy -g 2 11.155.183.0
type=ip, case=sensitive, match=no
  • Clear all entries from a acl
% haproxytool acl -D /run/haproxy -s 2
0x2115c90 11.155.183.41
0x3e92f80 10.10.10.10

% haproxytool acl -D /run/haproxy -c 2
all entries of acl were cleared successfully

% haproxytool acl -D /run/haproxy -s 2

%

Release

  1. Bump version in haproxytool/__init__.py

  2. Commit above change with:

    git commit -av -m'RELEASE 0.1.3 version'
    
  3. Create a signed tag, pbr will use this for the version number:

    git tag -s 0.1.3 -m 'bump release'
    
  4. Create the source distribution archive (the archive will be placed in the dist directory):

    python setup.py sdist
    
  5. pbr updates ChangeLog file and we want to squeeze this change to the previous commit, thus run:

    git commit -av --amend
    
  6. Move current tag to the last commit:

    git tag -fs 0.1.3 -m 'bump release'
    
  7. Push changes:

    git push;git push --tags
    

Installation

Use pip:

pip install haproxytool

From Source:

python setup.py install

Build (source) RPMs:

python setup.py clean --all; python setup.py bdist_rpm

Build a source archive for manual installation:

python setup.py sdist

Licensing

Apache 2.0

Acknowledgement

This program was originally developed for Booking.com. With approval from Booking.com, the code was generalised and published as Open Source on github, for which the author would like to express his gratitude.

Contacts

Project website: https://github.com/unixsurfer/haproxytool

Author: Pavlos Parissis <pavlos.parissis@gmail.com>