Developer Interface¶
This part of the documentation covers all the available interfaces of haproxyadmin package. Public and internal interfaces are described.
HAProxy
, Frontend
, Backend
and server
classes are the main 4 public interfaces.
These classes provide methods to run various operations. HAProxy provides a
several statistics which can be retrieved by calling metric()
, see
HAProxy statistics for the full list of statistics.
haproxyadmin.internal
module provides a set of classes that are not
meant for external use.
haproxyadmin.haproxy¶
This module implements the main haproxyadmin API.
-
class
haproxyadmin.haproxy.
HAProxy
(socket_dir=None, socket_file=None, retry=2, retry_interval=2)¶ Build a user-created
HAProxy
object for HAProxy.This is the main class to interact with HAProxy and provides methods to create objects for managing frontends, backends and servers. It also provides an interface to interact with HAProxy as a way to retrieve settings/statistics but also change settings.
ACLs and MAPs are also managed by
HAProxy
class.Parameters: - socket_dir (
string
) – a directory with HAProxy stats files. - socket_file (
string
) – absolute path of HAProxy stats file. - retry (
integer
orNone
) –number of times to retry to open a UNIX socket connection after a failure occurred, possible values
- None => don’t retry
- 0 => retry indefinitely
- 1..N => times to retry
- retry_interval (
integer
) – sleep time between the retries.
Returns: a user-created
HAProxy
object.Return type: -
add_acl
(acl, pattern)¶ Add an entry into the acl.
Parameters: - acl (
integer
or a file path passed asstring
) – acl id or a file. - pattern (
string
) – entry to add.
Returns: True
if command succeeds otherwiseFalse
Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_acl(acl=4) ['0x23181c0 /static/css/'] >>> hap.add_acl(acl=4, pattern='/foo/' ) True >>> hap.show_acl(acl=4) ['0x23181c0 /static/css/', '0x238f790 /foo/']
- acl (
-
add_map
(mapid, key, value)¶ Add an entry into the map.
Parameters: - mapid (
integer
or a file path passed asstring
) – map id or a file. - key (
string
) – key to add. - value (
string
) – Value assciated to the key.
Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_map(0) ['0x1a78b20 1 www.foo.com-1'] >>> hap.add_map(0, '9', 'foo') True >>> hap.show_map(0) ['0x1a78b20 1 www.foo.com-1', '0x1b15c80 9 foo']
- mapid (
-
backend
(name)¶ Build a
Backend
object.Parameters: name ( string
) – backend name to look up.Raises: :class::ValueError when backend isn’t found or more than 1 backend is found.
-
backends
(name=None)¶ Build a list of
Backend
Parameters: name ( string
) – (optional) backend name to look up.Returns: list of Backend
.Return type: list
-
clear_acl
(acl)¶ Remove all entries from a acl.
Parameters: acl ( integer
or a file path passed asstring
) – acl id or a file.Returns: True if command succeeds otherwise False Return type: bool Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.clear_acl(acl=4) True >>> hap.clear_acl(acl='/etc/haproxy/bl_frontend') True
-
clear_map
(mapid)¶ Remove all entries from a mapid.
Parameters: mapid ( integer
or a file path passed asstring
) – map id or a fileReturns: True
if command succeeds otherwiseFalse
Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.clear_map(0) True >>> hap.clear_map(mapid='/etc/haproxy/bl_frontend') True
-
clearcounters
(all=False)¶ Clear the max values of the statistics counters.
When
all
is set toTrue
clears all statistics counters in each proxy (frontend & backend) and in each server. This has the same effect as restarting.Parameters: all ( bool
) – (optional) clear all statistics counters.Returns: True
if command succeeds otherwiseFalse
.Return type: bool
-
command
(cmd)¶ Send a command to haproxy process.
This allows a user to send any kind of command to haproxy. We **do not* perfom any sanitization on input and on output.
Parameters: cmd ( string
) – a command to send to haproxy process.Returns: list of 2-item tuple - HAProxy process number
- what the method returned
Return type: list
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.command('show stats') ['0x23181c0 /static/css/'] >>> hap.add_acl(acl=4, pattern='/foo/' ) True >>> hap.show_acl(acl=4) ['0x23181c0 /static/css/', '0x238f790 /foo/']
-
del_acl
(acl, key)¶ Delete all the acl entries from the acl corresponding to the key.
Parameters: - acl (
integer
or a file path passed asstring
) – acl id or a file - key (
string
) – key to delete.
Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_acl(acl=4) ['0x23181c0 /static/css/', '0x238f790 /foo/', '0x238f810 /bar/'] >>> hap.del_acl(acl=4, key='/static/css/') True >>> hap.show_acl(acl=4) ['0x238f790 /foo/', '0x238f810 /bar/'] >>> hap.del_acl(acl=4, key='0x238f790') True >>> hap.show_acl(acl=4) ['0x238f810 /bar/']
- acl (
-
del_map
(mapid, key)¶ Delete all the map entries from the map corresponding to the key.
Parameters: - mapid (
integer
or a file path passed asstring
.) – map id or a file. - key (
string
) – key to delete
Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_map(0) ['0x1b15cd0 9 foo', '0x1a78980 11 bar'] >>> hap.del_map(0, '0x1b15cd0') True >>> hap.show_map(0) ['0x1a78980 11 bar'] >>> hap.add_map(0, '22', 'bar22') True >>> hap.show_map(0) ['0x1a78980 11 bar', '0x1b15c00 22 bar22'] >>> hap.del_map(0, '22') True >>> hap.show_map(0) ['0x1a78980 11 bar']
- mapid (
-
errors
(iid=None)¶ Dump last known request and response errors.
If <iid> is specified, the limit the dump to errors concerning either frontend or backend whose ID is <iid>.
Parameters: iid (integer) – (optional) ID of frontend or backend. Returns: A list of tuples of errors per process. - process number
list
of errors
Return type: list
-
frontend
(name)¶ Build a
Frontend
object.Parameters: name ( string
) – frontend name to look up.Returns: a Frontend
object for the frontend.Return type: Frontend
Raises: :class::ValueError when frontend isn’t found or more than 1 frontend is found.
-
frontends
(name=None)¶ Build a list of
Frontend
Parameters: name ( string
) – (optional) frontend name to look up.Returns: list of Frontend
.Return type: list
-
get_acl
(acl, value)¶ Lookup the value in the ACL.
Parameters: - acl (
integer
or a file path passed asstring
) – acl id or a file. - value (
string
) – value to lookup
Returns: matching patterns associated with ACL.
Return type: string
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_acl(acl=4) ['0x2318120 /static/js/', '0x23181c0 /static/css/'] >>> hap.get_acl(acl=4, value='/foo') 'type=beg, case=sensitive, match=no' >>> hap.get_acl(acl=4, value='/static/js/') 'type=beg, case=sensitive, match=yes, idx=tree, pattern="/static/js/"'
- acl (
-
get_map
(mapid, value)¶ Lookup the value in the map.
Parameters: - mapid (
integer
or a file path passed asstring
) – map id or a file. - value (
string
) – value to lookup.
Returns: matching patterns associated with map.
Return type: string
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_map(0) ['0x1a78980 11 new2', '0x1b15c00 22 0'] >>> hap.get_map(0, '11') 'type=str, case=sensitive, found=yes, idx=tree, key="11", value="new2", type="str"' >>> hap.get_map(0, '10') 'type=str, case=sensitive, found=no'
- mapid (
-
info
()¶ Dump info about haproxy stats on current process.
Returns: A list of dict
for each process.Return type: list
-
metric
(name)¶ Return the value of a metric.
Performs a calculation on the metric across all HAProxy processes. The type of calculation is either sum or avg and defined in
haproxyadmin.utils.METRICS_SUM
andhaproxyadmin.utils.METRICS_AVG
.Parameters: name (any of haproxyadmin.haproxy.HAPROXY_METRICS
) – metric name to retrieveReturns: value of the metric Return type: integer
Raise: ValueError
when a given metric is not found
-
server
(hostname, backend=None)¶ Build
Server <haproxyadmin.server.Server> for a server.
objects for the given server.If
backend
specified then lookup is limited to that backend.Note
If a server is member of more than 1 backend then muliple objects for the same server is returned.
Parameters: - hostname (
string
) – servername to look for. - backend (
string
) – (optional) backend name to look in.
Returns: a list of
Server
objects.Return type: list
- hostname (
-
servers
(backend=None)¶ Build
Server
for each server.If
backend
specified then lookup is limited to that backend.Parameters: backend ( string
) – (optional) backend name.Returns: A list of Server
objectsReturn type: list
.
-
set_map
(mapid, key, value)¶ Modify the value corresponding to each key in a map.
mapid is the #<id> or <file> returned by
show_map
.Parameters: - mapid (
integer
or a file path passed asstring
) – map id or a file. - key (
string
) – key id - value (
string
) – value to set for the key.
Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_map(0) ['0x1a78980 11 9', '0x1b15c00 22 0'] >>> hap.set_map(0, '11', 'new') True >>> hap.show_map(0) ['0x1a78980 11 new', '0x1b15c00 22 0'] >>> hap.set_map(0, '0x1a78980', 'new2') True >>> hap.show_map(0) ['0x1a78980 11 new2', '0x1b15c00 22 0']
- mapid (
-
setmaxconn
(value)¶ Set maximum connection to the frontend.
Parameters: value ( integer
) – value to set.Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.setmaxconn(5555) True
-
setratelimitconn
(value)¶ Set process-wide connection rate limit.
Parameters: value ( integer
) – rate connection limit.Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Raises: ValueError
if value is not aninteger
.
-
setratelimitsess
(value)¶ Set process-wide session rate limit.
Parameters: value ( integer
) – rate session limit.Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Raises: ValueError
if value is not aninteger
.
-
setratelimitsslsess
(value)¶ Set process-wide ssl session rate limit.
Parameters: value ( integer
) – rate ssl session limit.Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Raises: ValueError
if value is not aninteger
.
-
show_acl
(aclid=None)¶ Dump info about acls.
Without argument, the list of all available acls is returned. If a aclid is specified, its contents are dumped.
Parameters: aclid ( integer
or a file path passed asstring
) – (optional) acl id or a fileReturns: a list with the acls Return type: list
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_acl(aclid=6) ['0x1d09730 ver%3A27%3Bvar%3A0'] >>> hap.show_acl() ['# id (file) description', "1 () acl 'ssl_fc' file '/etc/haproxy/haproxy.cfg' line 83", "2 () acl 'src' file '/etc/haproxy/haproxy.cfg' line 95", "3 () acl 'path_beg' file '/etc/haproxy/haproxy.cfg' line 97", ]
-
show_map
(mapid=None)¶ Dump info about maps.
Without argument, the list of all available maps is returned. If a mapid is specified, its contents are dumped.
Parameters: mapid ( integer
or a file path passed asstring
) – (optional) map id or a file.Returns: a list with the maps. Return type: list
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.show_map() ['# id (file) description', "0 (/etc/haproxy/v-m1-bk) pattern loaded ...... line 82", ] >>> hap.show_map(mapid=0) ['0x1a78ab0 0 www.foo.com-0', '0x1a78b20 1 www.foo.com-1']
-
description
¶ Return description of HAProxy
Return type: string
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.description 'test'
-
maxconn
¶ Return the sum of configured maximum connection allowed for HAProxy.
Return type: integer
-
nodename
¶ Return nodename of HAProxy
Return type: string
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.nodename 'test.foo.com'
-
processids
¶ Return the process IDs of all HAProxy processes.
Return type: list
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.processids [22029, 22028, 22027, 22026]
-
ratelimitconn
¶ Return the process-wide connection rate limit.
-
ratelimitsess
¶ Return the process-wide session rate limit.
-
ratelimitsslsess
¶ Return the process-wide ssl session rate limit.
-
releasedate
¶ Return release date of HAProxy
Return type: string
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.releasedate '2014/10/31'
-
requests
¶ Return total requests processed by all frontends.
Return type: integer
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.requests 457
-
totalrequests
¶ Return total cumulative number of requests processed by all processes.
Return type: integer
Note
This is the total number of requests that are processed by HAProxy. It counts requests for frontends and backends. Don’t forget that a single client request passes HAProxy twice.
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.totalrequests 457
-
uptime
¶ Return uptime of HAProxy process
Return type: string Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.uptime '4d 0h16m26s'
-
uptimesec
¶ Return uptime of HAProxy process in seconds
Return type: integer
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.uptimesec 346588
-
version
¶ Return version of HAProxy
Return type: string
- Usage::
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> hap.version '1.5.8'
- socket_dir (
haproxyadmin.frontend¶
This module provides the Frontend
class. This class can
be used to run operations on a frontend and retrieve statistics.
-
class
haproxyadmin.frontend.
Frontend
(frontend_per_proc)¶ Build a user-created
Frontend
for a single frontend.Parameters: frontend_per_proc ( list
) – list of_Frontend
objects.Return type: a Frontend
.-
disable
()¶ Disable frontend.
Parameters: die ( bool
) – control the handling of errors.Returns: True
if frontend is disabled otherwiseFalse
.Return type: bool Raise: If die
isTrue
haproxyadmin.exceptions.CommandFailed
orhaproxyadmin.exceptions.MultipleCommandResults
is raised when something bad happens otherwise returnsFalse
.
-
enable
()¶ Enable frontend.
Parameters: die ( bool
) – control the handling of errors.Returns: True
if frontend is enabled otherwiseFalse
.Return type: bool Raise: If die
isTrue
haproxyadmin.exceptions.CommandFailed
orhaproxyadmin.exceptions.MultipleCommandResults
is raised when something bad happens otherwise returnsFalse
.
-
metric
(name)¶ Return the value of a metric.
Performs a calculation on the metric across all HAProxy processes. The type of calculation is either sum or avg and defined in
haproxyadmin.utils.METRICS_SUM
andhaproxyadmin.utils.METRICS_AVG
.Parameters: name (any of haproxyadmin.haproxy.FRONTEND_METRICS
) – metric name to retrieveReturns: value of the metric Return type: integer
Raise: ValueError
when a given metric is not found
-
requests_per_process
()¶ Return the number of requests for the frontend per process.
Returns: a list of tuples with 2 elements - process number of HAProxy
- requests
Return type: list
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> frontend = hap.frontend('frontend2_proc34') >>> frontend.requests_per_process() [(4, 2), (3, 3)]
-
setmaxconn
(value)¶ Set maximum connection to the frontend.
Parameters: - die (
bool
) – control the handling of errors. - value (
integer
) – max connection value.
Returns: True
if value was set.Return type: bool
Raise: If
die
isTrue
haproxyadmin.exceptions.CommandFailed
orhaproxyadmin.exceptions.MultipleCommandResults
is raised when something bad happens otherwise returnsFalse
.Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> frontend = hap.frontend('frontend1_proc34') >>> frontend.maxconn >>> frontend.setmaxconn(50000) True >>> frontend.maxconn 100000
- die (
-
shutdown
()¶ Disable the frontend.
Warning
HAProxy removes from the running configuration a frontend, so further operations on the frontend will return an error.
Return type: bool
-
stats_per_process
()¶ Return all stats of the frontend per process.
Returns: a list of tuples with 2 elements - process number
- a dict with all stats
Return type: list
-
iid
¶ Return the unique proxy ID of the frontend.
Note
Because proxy ID is the same across all processes, we return the proxy ID from the 1st process.
Return type: int
-
maxconn
¶ Return the configured maximum connection allowed for frontend.
Return type: integer
-
name
¶ Return the name of the frontend.
Return type: string
-
process_nb
¶ Return a list of process number in which frontend is configured.
Return type: list
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> frontend = hap.frontend('frontend2_proc34') >>> frontend.process_nb [4, 3]
-
requests
¶ Return the number of requests.
Return type: integer
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> frontend = hap.frontend('frontend2_proc34') >>> frontend.requests 5
-
status
¶ Return the status of the frontend.
Return type: string
Raise: IncosistentData
exception if status is different per processUsage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> frontend = hap.frontend('frontend2_proc34') >>> frontend.status 'OPEN'
-
haproxyadmin.backend¶
This module provides the Backend
class which allows to
run operation for a backend.
-
class
haproxyadmin.backend.
Backend
(backend_per_proc)¶ Build a user-created
Backend
for a single backend.Parameters: backend_per_proc ( list
) – list of_Backend
objects.Return type: a Backend
.-
metric
(name)¶ Return the value of a metric.
Performs a calculation on the metric across all HAProxy processes. The type of calculation is either sum or avg and defined in utils.METRICS_SUM and utils.METRICS_AVG.
Parameters: name ( string
) – Name of the metric, any of BACKEND_METRICSReturns: Value of the metric after the appropriate calculation has been performed. Return type: number, either integer
orfloat
.Raise: ValueError when a given metric is not found.
-
requests_per_process
()¶ Return the number of requests for the backend per process.
Returns: a list of tuples with 2 elements - process number of HAProxy
- requests
Return type: list
-
server
(name)¶ Return a Server object
Parameters: name (string) – Name of the server Returns: Server
objectReturn type: haproxyadmin.Server
-
servers
(name=None)¶ Return Server object for each server.
Parameters: name (string) – (optional) servername to look for. Defaults to None. Returns: A list of Server
objectsReturn type: list
-
stats_per_process
()¶ Return all stats of the backend per process.
Returns: a list of tuples with 2 elements - process number
- a dict with all stats
Return type: list
-
iid
¶ Return the unique proxy ID of the backend.
Note
Because proxy ID is the same across all processes, we return the proxy ID from the 1st process.
Return type: int
-
name
¶ Return the name of the backend.
Return type: string
-
process_nb
¶ Return a list of process number in which backend is configured.
Return type: list
-
requests
¶ Return the number of requests.
Return type: integer
-
status
¶ Return the status of the backend.
Return type: string
Raise: IncosistentData
exception if status is different per process.
-
haproxyadmin.server¶
This module provides the Server
class which allows to
run operation for a server.
-
class
haproxyadmin.server.
Server
(server_per_proc, backendname)¶ Build a user-created
Server
for a single server.Parameters: _server_per_proc ( list
) – list of_Server
objects.Return type: a Server
.-
metric
(name)¶ Return the value of a metric.
Performs a calculation on the metric across all HAProxy processes. The type of calculation is either sum or avg and defined in
haproxyadmin.utils.METRICS_SUM
andhaproxyadmin.utils.METRICS_AVG
.Parameters: name (any of haproxyadmin.haproxy.SERVER_METRICS
) – The name of the metricReturn type: number, integer Raise: ValueError
when a given metric is not found
-
requests_per_process
()¶ Return the number of requests for the server per process.
Return type: A list of tuple, where 1st element is process number and 2nd element is requests.
-
setstate
(state)¶ Set the state of a server in the backend.
State can be any of the following
haproxyadmin.STATE_ENABLE
: Mark the server UP and checks are re-enabledhaproxyadmin.STATE_DISABLE
: Mark the server DOWN for maintenance and checks disabled.haproxyadmin.STATE_READY
: Put server in normal mode.haproxyadmin.STATE_DRAIN
: Remove the server from load balancing.haproxyadmin.STATE_MAINT
: Remove the server from load balancing and health checks are disabled.
Parameters: state ( string
) – state to set.Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Usage:
>>> from haproxyadmin import haproxy, STATE_DISABLE, STATE_ENABLE >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> server = hap.server('member_bkall', backend='backend_proc1')[0] >>> server.setstate(haproxy.STATE_DISABLE) True >>> server.status 'MAINT' >>> server.setstate(haproxy.STATE_ENABLE) True >>> server.status 'no check'
-
setweight
(value)¶ Set a weight.
If the value ends with the ‘%’ sign, then the new weight will be relative to the initially configured weight. Absolute weights are permitted between 0 and 256.
Parameters: value (integer or string with '%' sign) – Weight to set Returns: True
if command succeeds otherwiseFalse
.Return type: bool
Usage:
>>> from haproxyadmin import haproxy >>> hap = haproxy.HAProxy(socket_dir='/run/haproxy') >>> server = hap.server('member_bkall', backend='backend_proc1')[0] >>> server.weight 100 >>> server.setweight('20%') True >>> server.weight 20 >>> server.setweight(58) True >>> server.weight 58
-
shutdown
()¶ Terminate all the sessions attached to the specified server.
Returns: True
if command succeeds otherwiseFalse
.Return type: bool
-
stats_per_process
()¶ Return all stats of the server per process.
Returns: A list of tuple 2 elements - process number
- a dict with all stats
Return type: list
-
address
¶ The assigned address of server.
Getter: rtype: string
Setter: param address: address to set. type address: string
rtype: bool
-
check_code
¶ Return the check code.
Return type: integer
-
check_status
¶ Return the check status.
Return type: string
-
last_agent_check
¶ Return the last agent check contents or textual error.
Return type: string
-
last_status
¶ Return the last health check contents or textual error.
Return type: string
-
name
¶ Return the name of the server.
Return type: string
-
port
¶ The assigned port of server.
Getter: rtype: string
Setter: param port: port to set. type port: string
rtype: bool
-
process_nb
¶ Return a list of process number in which backend server is configured.
Returns: a list of process numbers. Return type: list
-
requests
¶ Return the number of requests.
Return type: integer
-
sid
¶ Return the unique proxy server ID of the server.
Note
Because server ID is the same across all processes, we return the proxy ID from the 1st process.
Return type: int
-
status
¶ Return the status of the server.
Return type: string
Raise: IncosistentData
exception if status is different per process
-
weight
¶ Return the weight.
Return type: integer
Raise: IncosistentData
exception if weight is different per process
-
haproxyadmin.internal.haproxy¶
This module provides the main class that is used within haproxyadmin for creating object to work with a single HAProxy process. All other internal classes use this class to send commands to HAProxy process.
-
class
haproxyadmin.internal.haproxy.
_HAProxyProcess
(socket_file, retry=3, retry_interval=2)¶ An object to a single HAProxy process.
It acts as a communication pipe between the caller and individual HAProxy process using UNIX stats socket.
Parameters: - socket_file (string) – Full path of socket file.
- retry (integer) – (optional) Number of connect retries (defaults to 3)
- retry_interval (integer) – (optional) Interval time in seconds between retries (defaults to 2)
-
backends
(name=None)¶ Build _backend objects for each backend.
Parameters: name (string) – (optional) backend name, defaults to None Returns: a list of _backend objects for each backend Return type: list
-
backends_stats
(iid=-1)¶ Build the data structure for backends
If
iid
is set then builds a structure only for the particul backend.Parameters: iid ( string
) – (optinal) unique proxy id of a backend.Retur: a dictinary with backend information. Return type: dict
-
command
(command, full_output=False)¶ Send a command to HAProxy over UNIX stats socket.
Newline character returned from haproxy is stripped off.
Parameters: - command (string) – A valid command to execute
- full_output (
bool
) – (optional) Return all output, by default returns only the 1st line of the output
Returns: 1st line of the output or the whole output as a list
Return type: string
orlist
if full_output is True
-
frontends
(name=None)¶ Build
_Frontend
objects for each frontend.Parameters: name ( string
) – (optional) backend name, defaults toNone
Returns: a list of _Frontend
objects for each backendReturn type: list
-
frontends_stats
(iid=-1)¶ Build the data structure for frontends
If
iid
is set then builds a structure only for the particular frontend.Parameters: iid ( string
) – (optinal) unique proxy id of a frontend.Retur: a dictinary with frontend information. Return type: dict
-
proc_info
()¶ Return a dictionary containing information about HAProxy daemon.
Return type: dictionary, see utils.info2dict() for details
-
stats
(iid=-1, obj_type=-1, sid=-1)¶ Return a nested dictionary containing backend information.
Parameters: - iid (
string
) – unique proxy id, applicable for frontends and backends. - obj_type (
integer
) –selects the type of dumpable objects
- 1 for frontends
- 2 for backends
- 4 for servers
- -1 for everything.
These values can be ORed, for example:
1 + 2 = 3 -> frontend + backend. 1 + 2 + 4 = 7 -> frontend + backend + server.
- sid (
integer
) – a server ID, -1 to dump everything.
Return type: dict, see
utils.stat2dict
for details on the structure- iid (
haproxyadmin.internal.frontend¶
This module provides a class, which is used within haproxyadmin for creating a object to work with a frontend. This object is associated only with a single HAProxy process.
-
class
haproxyadmin.internal.frontend.
_Frontend
(hap_process, name, iid)¶ Class for interacting with a frontend in one HAProxy process.
Parameters: - hap_process – a
_HAProxyProcess
object. - name (
string
) – frontend name. - iid (
integer
) – unique proxy id of the frontend.
-
command
(cmd)¶ Run command to HAProxy
Parameters: cmd ( string
) – a valid command to execute.Returns: 1st line of the output. Return type: string
-
metric
(name)¶ Return the value of a metric
-
stats
()¶ Build dictionary for all statistics reported by HAProxy.
return: A dictionary with statistics rtype: dict
- split internal to multiple files
-
stats_data
()¶ Return stats data
Return type: utils.CSVLine
objectHAProxy assigns unique ids to each object during the startup. The id can change when configuration changes, objects order is reshuffled or additions/removals take place. In those cases the id we store at the instantiation of the object may reference to another object or even to non-existent object when configuration takes places afterwards.
The technique we use is quite simple. When an object is created we store the name and the id. In order to detect if iid is changed, we simply send a request to fetch data only for the given iid and check if the current id points to an object of the same type (frontend, backend, server) which has the same name.
-
iid
¶ Return Proxy ID
-
name
¶ Return a string which is the name of the frontend
- hap_process – a
haproxyadmin.internal.backend¶
This module provides a class, which is used within haproxyadmin for creating a object to work with a backend. This object is associated only with a single HAProxy process.
-
class
haproxyadmin.internal.backend.
_Backend
(hap_process, name, iid)¶ Class for interacting with a backend in one HAProxy process.
Parameters: - hap_process – a :class::_HAProxyProcess object.
- name (
string
) – backend name. - iid (
integer
) – unique proxy id of the backend.
-
command
(cmd)¶ Send command to HAProxy
Parameters: cmd ( string
) – command to sendReturns: the output of the command Return type: string
-
servers
(name=None)¶ Return a list of _Server objects for each server of the backend.
Parameters: name ( string
) – (optional): server name to lookup, defaults to None.
-
stats
()¶ Build dictionary for all statistics reported by HAProxy.
Returns: A dictionary with statistics Return type: dict
-
stats_data
()¶ Return stats data
Check documentation of
stats_data
method in_Frontend
.Return type: utils.CSVLine
object
-
iid
¶ Return Proxy ID
-
name
¶ Return a string which is the name of the backend
-
process_nb
¶ Return the process number of the haproxy process
Return type: int
haproxyadmin.internal.server¶
This module provides a class, which is used within haproxyadmin for creating a object to work with a server. This object is associated only with a single HAProxy process.
-
class
haproxyadmin.internal.server.
_Server
(backend, name, sid)¶ Class for interacting with a server of a backend in one HAProxy.
Parameters: - backend – a _Backend object in which server is part of.
- name (
string
) – server name. - sid (
string
) – server id (unique inside a proxy).
-
stats
()¶ Build dictionary for all statistics reported by HAProxy.
Returns: A dictionary with statistics Return type: dict
-
stats_data
()¶ Return stats data
Check documentation of
stats_data
method in_Frontend
.Return type: utils.CSVLine
object
-
name
¶ Return the name of the backend server.
-
sid
¶ Return server id
haproxyadmin.utils¶
This module provides utility functions and classes that are used within haproxyadmin.
-
class
haproxyadmin.utils.
CSVLine
(parts)¶ An object that holds field/value of a CSV line.
The field name becomes the attribute of the class. Needs the header line of CSV during instantiation.
Parameters: parts (list) – A list with field values Usage:
>>> from haproxyadmin import utils >>> heads = ['pxname', 'type', 'lbtol'] >>> parts = ['foor', 'backend', '444'] >>> utils.CSVLine.heads = heads >>> csvobj = utils.CSVLine(parts) >>> csvobj.pxname 'foor' >>> csvobj.type 'backend' >>> csvobj.lbtol '444' >>> csvobj.bar Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/.../haproxyadmin/haproxyadmin/utils.py", line 341, in __getattr__ _index = self.heads.index(attr) ValueError: 'bar' is not in list
-
haproxyadmin.utils.
calculate
(name, metrics)¶ Perform the appropriate calculation across a list of metrics.
Parameters: - name (
string
) – name of the metric. - metrics (
list
) – a list of metrics. Elements need to be eitherint
orfloat
type number.
Returns: either the sum or the average of metrics.
Return type: integer
Raise: ValueError
when matric name has unknown type of calculation.- name (
-
haproxyadmin.utils.
check_command
(results)¶ Check if command was successfully executed.
After a command is executed. We care about the following cases:
- The same output is returned by all processes
- If output matches to a list of outputs which indicate that command was valid
Parameters: results ( list
) –a list of tuples with 2 elements.
- process number of HAProxy
- message returned by HAProxy
Returns: True
if command was successfully executed otherwiseFalse
.Return type: bool
Raise: MultipleCommandResults
when output differers.
-
haproxyadmin.utils.
check_command_addr_port
(change_type, results)¶ Check if command to set port or address was successfully executed.
Unfortunately, haproxy returns many different combinations of output when we change the address or the port of the server and trying to determine if address or port was successfully changed isn’t that trivial.
So, after we change address or port, we check if the same output is returned by all processes and we also check if a collection of specific strings are part of the output. This is a suboptimal solution, but I couldn’t come up with something more elegant.
Parameters: - change_type (
string
) – eitheraddr
orport
- results (
list
) –a list of tuples with 2 elements.
- process number of HAProxy
- message returned by HAProxy
Returns: True
if command was successfully executed otherwiseFalse
.Return type: bool
Raise: MultipleCommandResults
,CommandFailed
andValueError
.- change_type (
-
haproxyadmin.utils.
check_output
(output)¶ Check if output contains any error.
Several commands return output which we need to return back to the caller. But, before we return anything back we want to perform a sanity check on on the output in order to catch wrong input as it is impossible to perform any sanitization on values/patterns which are passed as input to the command.
Parameters: output ( list
) – output of the command.Returns: True
if no errors found in output otherwiseFalse
.Return type: bool
-
haproxyadmin.utils.
cmd_across_all_procs
(hap_objects, method, *arg, **kargs)¶ Return the result of a command executed in all HAProxy process.
Note
Objects must have a property with the name ‘process_nb’ which returns the HAProxy process number.
Parameters: - hap_objects (
list
) – a list of objects. - method – a valid method for the objects.
Returns: list of 2-item tuple
- HAProxy process number
- what the method returned
Return type: list
- hap_objects (
-
haproxyadmin.utils.
compare_values
(values)¶ Run an intersection test across values returned by processes.
It is possible that not all processes return the same value for certain keys(status, weight etc) due to various reasons. We must detect these cases and either return the value which is the same across all processes or raise
<IncosistentData>
.Parameters: values ( list
) –a list of tuples with 2 elements.
- process number of HAProxy process returned the data
- value returned by HAProxy process.
Returns: value Return type: string
Raise: IncosistentData
.
-
haproxyadmin.utils.
connected_socket
(path)¶ Check if socket file is a valid HAProxy socket file.
We send a ‘show info’ command to the socket, build a dictionary structure and check if ‘Name’ key is present in the dictionary to confirm that there is a HAProxy process connected to it.
Parameters: path ( string
) – file name pathReturns: True
is socket file is a valid HAProxy stats socket file False otherwiseReturn type: bool
-
haproxyadmin.utils.
converter
(value)¶ Tries to convert input value to an integer.
If input can be safely converted to number it returns an
int
type. If input is a valid string but not an empty one it returns that. In all other cases we return None, including the ones which anTypeError
exception is raised byint()
. For floating point numbers, it truncates towards zero.Why are we doing this? HAProxy may return for a metric either a number or zero or string or an empty string.
It is up to the caller to correctly use the returned value. If the returned value is passed to a function which does math operations the caller has to filtered out possible
None
values.Parameters: value ( string
) – a value to convert to int.Return type: integer or ``string
orNone
if value can’t be converted toint
or tostring
.Usage:
>>> from haproxyadmin import utils >>> utils.converter('0') 0 >>> utils.converter('13.5') 13 >>> utils.converter('13.5f') '13.5f' >>> utils.converter('') >>> utils.converter(' ') >>> utils.converter('UP') 'UP' >>> utils.converter('UP 1/2') 'UP 1/2' >>>
-
haproxyadmin.utils.
elements_of_list_same
(iterator)¶ Check is all elements of an iterator are equal.
Parameters: iterator ( list
) – a iteratorReturn type: bool
Usage:
>>> from haproxyadmin import utils >>> iterator = ['OK', 'ok'] >>> utils.elements_of_list_same(iterator) False >>> iterator = ['OK', 'OK'] >>> utils.elements_of_list_same(iterator) True >>> iterator = [22, 22, 22] >>> utils.elements_of_list_same(iterator) True >>> iterator = [22, 22, 222] >>> utils.elements_of_list_same(iterator) False
-
haproxyadmin.utils.
info2dict
(raw_info)¶ Build a dictionary structure from the output of ‘show info’ command.
Parameters: raw_info ( list
) – data returned by ‘show info’ UNIX socket commandReturns: A dictionary with the following keys/values(examples) { Name: HAProxy Version: 1.4.24 Release_date: 2013/06/17 Nbproc: 1 Process_num: 1 Pid: 1155 Uptime: 5d 4h42m16s Uptime_sec: 448936 Memmax_MB: 0 Ulimit-n: 131902 Maxsock: 131902 Maxconn: 65536 Maxpipes: 0 CurrConns: 1 PipesUsed: 0 PipesFree: 0 Tasks: 819 Run_queue: 1 node: node1 description: }
Return type: dict
-
haproxyadmin.utils.
is_unix_socket
(path)¶ Return
True
if path is a valid UNIX socket otherwise False.Parameters: path ( string
) – file name pathReturn type: bool
-
haproxyadmin.utils.
isint
(value)¶ Check if input can be converted to an integer
Parameters: value (a string
orint
) – value to checkReturns: True
if value can be converted to an integerReturn type: bool
Raise: ValueError
when value can’t be converted to an integer
-
haproxyadmin.utils.
should_die
(old_implementation)¶ Build a decorator to control exceptions.
When a function raises an exception in some cases we don’t care for the reason but only if the function run successfully or not. We add an extra argument to the decorated function with the name
die
to control this behavior. When it is set toTrue
, which is the default value, it raises any exception raised by the decorated function. When it is set toFalse
it returnsTrue
if decorated function run successfully orFalse
if an exception was raised.
-
haproxyadmin.utils.
stat2dict
(csv_data)¶ Build a nested dictionary structure.
Parameters: csv_data ( list
) – data returned by ‘show stat’ command in a CSV format.Returns: a nested dictionary with all counters/settings found in the input. Following is a sample of the structure: { 'backends': { 'acq-misc': { 'stats': { _CSVLine object }, 'servers': { 'acqrdb-01': { _CSVLine object }, 'acqrdb-02': { _CSVLine object }, ... } }, ... }, 'frontends': { 'acq-misc': { _CSVLine object }, ... }, ... }
Return type: dict
haproxyadmin.exceptions¶
This module contains the set of haproxyadmin’ exceptions with the following hierarchy:
HAProxyBaseError
├── CommandFailed
├── HAProxyDataError
│ ├── IncosistentData
│ └── MultipleCommandResults
└── HAProxySocketError
├── SocketApplicationError
├── SocketConnectionError
├── SocketPermissionError
├── SocketTimeout
└── SocketTransportError
-
exception
haproxyadmin.exceptions.
CommandFailed
(message='')¶ Raised when a command to HAProxy returned an error.
-
exception
haproxyadmin.exceptions.
HAProxyBaseError
(message='')¶ haproxyadmin base exception.
Parameters: message ( string
) – error message.
-
exception
haproxyadmin.exceptions.
HAProxyDataError
(results)¶ Base DataError class.
Parameters: results ( list
oflist
) – A structure which contains data returned be each socket.
-
exception
haproxyadmin.exceptions.
HAProxySocketError
(socket_file)¶ Base SocketError class.
Parameters: socket_file ( string
) – socket file.
-
exception
haproxyadmin.exceptions.
IncosistentData
(results)¶ Data across all processes is not the same.
-
exception
haproxyadmin.exceptions.
MultipleCommandResults
(results)¶ Command returned different results per HAProxy process.
-
exception
haproxyadmin.exceptions.
SocketApplicationError
(socket_file)¶ Raised when we connect to a socket and HAProxy is not bound to it.
-
exception
haproxyadmin.exceptions.
SocketConnectionError
(socket_file)¶ Raised when socket file is not bound to a process.
-
exception
haproxyadmin.exceptions.
SocketPermissionError
(socket_file)¶ Raised when permissions are not granted to access socket file.
-
exception
haproxyadmin.exceptions.
SocketTimeout
(socket_file)¶ Raised when we timeout on the socket.
-
exception
haproxyadmin.exceptions.
SocketTransportError
(socket_file)¶ Raised when endpoint of socket hasn’t closed an old connection.
Note
It only occurs in cases where HAProxy is ~90% CPU utilization for processing traffic and we reconnect to the socket too fast and as a result HAProxy doesn’t have enough time to close the previous connection.
Constants¶
Metric names¶
Various stats field names for which a value can be retrieved by using
metric
method available in all public and internal interfaces.
-
haproxyadmin.
FRONTEND_METRICS
= a list of metric names for retrieving varius statistics for frontends¶
-
haproxyadmin.
BACKEND_METRICS
= a list of metric names for retrieving varius statistics for backends¶
-
haproxyadmin.
SERVER_METRICS
= a list of metric names for retrieving varius statistics for servers¶
Aggregation rules¶
The following 2 constants define the type of aggregation, either sum or average, which is performed for values returned by all HAProxy processes.
-
haproxyadmin.utils.
METRICS_SUM
= ['CompressBpsIn', 'CompressBpsOut', 'CompressBpsRateLim', 'ConnRate', 'ConnRateLimit', 'CumConns', 'CumReq', 'CumSslConns', 'CurrConns', 'CurrSslConns', 'Hard_maxconn', 'Idle_pct', 'MaxConnRate', 'MaxSessRate', 'MaxSslConns', 'MaxSslRate', 'MaxZlibMemUsage', 'Maxconn', 'Maxpipes', 'Maxsock', 'Memmax_MB', 'PipesFree', 'PipesUsed', 'Process_num', 'Run_queue', 'SessRate', 'SessRateLimit', 'SslBackendKeyRate', 'SslBackendMaxKeyRate', 'SslCacheLookups', 'SslCacheMisses', 'SslFrontendKeyRate', 'SslFrontendMaxKeyRate', 'SslFrontendSessionReuse_pct', 'SslRate', 'SslRateLimit', 'Tasks', 'Ulimit-n', 'ZlibMemUsage', 'bin', 'bout', 'chkdown', 'chkfail', 'comp_byp', 'comp_in', 'comp_out', 'comp_rsp', 'cli_abrt', 'dreq', 'dresp', 'ereq', 'eresp', 'econ', 'hrsp_1xx', 'hrsp_2xx', 'hrsp_3xx', 'hrsp_4xx', 'hrsp_5xx', 'hrsp_other', 'lbtot', 'qcur', 'qmax', 'rate', 'rate_lim', 'rate_max', 'req_rate', 'req_rate_max', 'req_tot', 'scur', 'slim', 'srv_abrt', 'smax', 'stot', 'wretr', 'wredis']¶ Built-in mutable sequence.
If no argument is given, the constructor creates a new empty list. The argument must be an iterable if specified.
-
haproxyadmin.utils.
METRICS_AVG
= ['act', 'bck', 'check_duration', 'ctime', 'downtime', 'lastchg', 'lastsess', 'qlimit', 'qtime', 'rtime', 'throttle', 'ttime', 'weight']¶ Built-in mutable sequence.
If no argument is given, the constructor creates a new empty list. The argument must be an iterable if specified.