/herald

Load feedback and check agent for Haproxy

Primary LanguagePythonMIT LicenseMIT

Herald

Herald is a load feedback and check agent for Haproxy.

The agent is configured in Haproxy using the agent-check server option. Once enabled haproxy periodically (agent-inter) connects to the backend on the configured port (agent-port) and acts on the response.

The response can either indicate an action to perform, such as MAINT, UP, DRAIN, etc or change the weight of the respective backend with a percentage, say 75%. Check Haproxy documentation here for more details.

There are many use cases for using the agent, load feedback being an obvious one.

Goals

  • Flexible and easy to configure
  • Extensible using plugins
  • High performance

Install

We recommend using pip to install in a virtualenv :

$ virtualenv herald
$ pip install haproxy-herald

Configuration

In your haproxy backend add the agent-check configuration like so :

frontend myservice
        bind *:8004
        maxconn 20000
        option tcp-smart-accept
        default_backend myservers

backend myservers
        balance leastconn
        option tcp-smart-connect
        fullconn 20000
        server myserver01 myserver01:8081       maxconn 10000 weight 100 check agent-check agent-port 5555
        server myserver02 myserver02:8081       maxconn 10000 weight 100 check agent-check agent-port 5555
        server myserver03 myserver03:8081       maxconn 10000 weight 100 check agent-check agent-port 5555

This instructs haproxy to connect to agent on port 5555.

On the backend servers, run herald with the following configuration :

---
name: myservice
bind: 0.0.0.0
port: 5555
plugins_dir: /etc/herald/plugins
plugins:
  - name: myservice_plugin
    herald_plugin_name: herald_http
    url: 'http://localhost:8081/health_check'
    is_json: yes
    stop_timeout: 60
    interval: 30
    staleness_interval: 120
    staleness_response: noop
    thresholds_metric: "r['msg-pre-second']"
    thresholds:
      - pct: 7000
        min_threshold_response: 1
    default_response: noop

Herald reads from /etc/herald/config.yml by default. The plugins are bundled in herald.plugins, which can be symlinked in /etc/herald/plugins.

Check the example_config.yml file for detailed configuration options.

With this configuration, herald will poll the health check url every 30s. Note that the response is also cached to avoid hitting the health check url too often.

Plugins

The herald_http and herald_file plugins are provided in herald/plugins directory. These should serve most use cases. The plugin code is simple and easy to follow; Writing additional plugins should be very easy.

The following features are provided by the plugin framework :

  • Check result cacheing
  • Json parsing and processing parsed data using any python dict expression
  • Arthmetic expressions on the result
  • Calculate weight percentage on the result
  • Regex pattern matching on the result

Future

  • Unit and integration tests
  • Improved logging
  • Configuration reload on SIGHUP